坑 - 當(dāng)insert ignore遇到not null

表中存在唯一索引時,有時候?yàn)榱吮苊獠迦胫貜?fù)數(shù)據(jù),我們會使用MySQL的INSERT IGNORE語法,這樣如果唯一索引有沖突就會自動忽略。 看起來很完美的一個解決辦法,但是背后隱藏著一個坑,最后不得不放棄。

不僅僅是DUPLICATE KEY

INSERT IGNORE不僅僅會忽略DUPLICATE KEY錯誤,也會忽略非空錯誤

  • 數(shù)據(jù)庫有表student如下:
mysql> show create table student;
+---------+----------------------------+
| Table   | Create Table               |
+---------+----------------------------+
| student | CREATE TABLE `student` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(16) NOT NULL,
  `class_id` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+---------+----------------------------+
1 row in set (0.00 sec)
  • 因?yàn)?code>class_id非空,所以插入失敗
mysql> insert into student(name) values("tenmao");
ERROR 1364 (HY000): Field 'class_id' doesn't have a default value
  • 使用ignore后插入失敗,class_id被設(shè)置為int的默認(rèn)值0
mysql> insert ignore into student(name) values("tenmao");
Query OK, 1 row affected, 1 warning (0.01 sec)

mysql> show warnings;
+---------+------+-----------------------------------------------+
| Level   | Code | Message                                       |
+---------+------+-----------------------------------------------+
| Warning | 1364 | Field 'class_id' doesn't have a default value |
+---------+------+-----------------------------------------------+
1 row in set (0.00 sec)

mysql> select * from student;
+----+--------+----------+
| id | name   | class_id |
+----+--------+----------+
|  1 | tenmao |        0 |
+----+--------+----------+
1 row in set (0.00 sec)
  • varchar會被設(shè)置為默認(rèn)值''(空字符串)
mysql> insert ignore into student(class_id) values(1);
Query OK, 1 row affected, 1 warning (0.01 sec)

mysql> select * from student;
+----+--------+----------+
| id | name   | class_id |
+----+--------+----------+
|  1 | tenmao |        0 |
|  2 |        |        1 |
+----+--------+----------+
2 rows in set (0.00 sec)

字段NOT NULL是為了防止插入時漏掉這個字段,但是使用INSERT IGNORE后,會自動設(shè)置一個沒有用的默認(rèn)值,導(dǎo)致系統(tǒng)數(shù)據(jù)錯誤。 那怎么辦?


ON DUPLICATE KEY

解決辦法也很簡單,使用ON DUPLICATE KEY

mysql> insert into student(id, name, class_id) values(1, '十毛', 2);
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
mysql> insert into student(id, name, class_id) values(1, '十毛', 2) on duplicate key update id=id;
Query OK, 0 rows affected (0.00 sec)

參考

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容