濮阳杆衣贸易有限公司

主頁 > 知識庫 > 詳解MySQL主鍵唯一鍵重復(fù)插入解決方法

詳解MySQL主鍵唯一鍵重復(fù)插入解決方法

熱門標(biāo)簽:電話機(jī)器人接口是什么樣的 沈陽外呼系統(tǒng)有效果嗎 四川穩(wěn)定外呼系統(tǒng)公司 AI智能云呼電話機(jī)器人怎么注冊 怎么在高德地圖標(biāo)注多個點(diǎn) 百度地圖標(biāo)注信息怎么修改 福州外呼系統(tǒng)招商 商家地圖標(biāo)注圖片 溫州語音外呼系統(tǒng)排名

我們插入數(shù)據(jù)的時候,有可能碰到重復(fù)數(shù)據(jù)插入的問題,但是這些數(shù)據(jù)又是不被允許有重復(fù)值:

CREATE TABLE stuInfo (
  id INT NOT NULL COMMENT '序號',
  name VARCHAR(20) NOT NULL DEFAULT '' COMMENT '姓名',
  age INT NOT NULL DEFAULT 0 COMMENT '年齡',
  PRIMARY KEY (id),
  UNIQUE KEY uniq_name(name)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='學(xué)生表';
mysql> INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25),(2,'aa',24);
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

解決方案:

1. IGNORE

使用ignore當(dāng)插入的值遇到主鍵(PRIMARY KEY)或者唯一鍵(UNIQUE KEY)重復(fù)時自動忽略重復(fù)的記錄行,不影響后面的記錄行的插入。

INSERT IGNORE INTO stuInfo (name,birthday,is_deleted) VALUES ('yoona','1990-01-05',0),('aa','1990-01-16',0),('bb','1990-01-17',0);

運(yùn)行結(jié)果:

mysql> INSERT IGNORE INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25),(2,'aa',24);
Query OK, 2 rows affected (0.02 sec)
Records: 3  Duplicates: 1  Warnings: 0
mysql> select * from stuInfo; 
+----+-------+-----+
| id | name  | age |
+----+-------+-----+
|  1 | yoona |  20 |
|  2 | aa    |  24 |
+----+-------+-----+
2 rows in set (0.00 sec)

我們可以從運(yùn)行結(jié)果中看出,只有兩行受到影響,意思即(1,'yoona',20)數(shù)據(jù)插入,(1,'xiaosi',25)重復(fù)數(shù)據(jù)自動被忽略,(2,'aa',24)不重復(fù)數(shù)據(jù)繼續(xù)插入,不會受到重復(fù)數(shù)據(jù)的影響;

2. REPLACE

使用replace當(dāng)插入的記錄遇到主鍵或者唯一鍵重復(fù)時先刪除表中重復(fù)的記錄行再插入。

mysql> REPLACE INTO stuInfo (name,birthday,is_deleted) VALUES ('yoona','1990-01-15',0),('yoona','1990-02-16',0),('aa','1990-01-13',0);
Query OK, 4 rows affected (0.02 sec)
Records: 3  Duplicates: 1  Warnings: 0
運(yùn)行結(jié)果:
 
mysql> select * from stuInfo;                                                   +----+-------+------------+------------+
| id | name  | birthday   | is_deleted |
+----+-------+------------+------------+
| 21 | yoona | 1990-02-16 |          0 |
| 22 | aa    | 1990-01-13 |          0 |
+----+-------+------------+------------+
2 rows in set (0.00 sec)

從輸出的信息可以看到是4行受影響,說明它是先插入了(‘yoona','1990-01-15',0)然后又刪除了(‘yoona','1990-01-15',0)。

3. ON DUPLICATE KEY UPDATE

當(dāng)插入的記錄遇到主鍵或者唯一鍵重復(fù)時,會執(zhí)行后面定義的UPDATE操作。相當(dāng)于先執(zhí)行Insert 操作,再根據(jù)主鍵或者唯一鍵執(zhí)行update操作。

DROP TABLE  IF EXISTS stuInfo;
CREATE TABLE stuInfo (
  id INT NOT NULL COMMENT '序號',
  name VARCHAR(20) NOT NULL DEFAULT '' COMMENT '姓名',
  age INT NOT NULL DEFAULT 0 COMMENT '年齡',
  PRIMARY KEY (id),
  UNIQUE KEY uniq_name(name)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='學(xué)生表';

在ON DUPLICATE KEY UPDATE后VALUES解釋:

VAULES(age)指的是待插入的記錄的值

age指得是表的自身值,已插入值。

(1)第一種情形:

#VALUES(age) 待插入值 25
INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25) ON DUPLICATE KEY UPDATE age = VALUES(age) + 1;

相當(dāng)于:

INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20);
UPDATE stuInfo 
SET age = VALUES(age) + 1
WHERE id = 1;

運(yùn)行結(jié)果:

mysql> INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25) ON DUPLICATE KEY UPDATE age = VALUES(age) + 1;
Query OK, 3 rows affected (0.01 sec)
Records: 2  Duplicates: 1  Warnings: 0
mysql> select * from stuInfo;   
+----+-------+-----+
| id | name  | age |
+----+-------+-----+
|  1 | yoona |  26 |
+----+-------+-----+
1 row in set (0.00 sec)

(2)第二種情形:

#age 已插入值 20
INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25) ON DUPLICATE KEY UPDATE age = age + 1;

相當(dāng)于:

INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20);
UPDATE stuInfo 
SET age = age + 1
WHERE id = 1;

運(yùn)行結(jié)果:

mysql> INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25) ON DUPLICATE KEY UPDATE age = age + 1;
Query OK, 3 rows affected (0.02 sec)
Records: 2  Duplicates: 1  Warnings: 0
mysql> select * from stuInfo;
 +----+-------+-----+
| id | name  | age |
+----+-------+-----+
|  1 | yoona |  21 |
+----+-------+-----+
1 row in set (0.00 sec)

如果遇到重復(fù)插入的數(shù)據(jù)的情形,ON DUPLICATE KEY UPDATE用來對已插入的數(shù)據(jù)進(jìn)行修改,可以使用獲取重復(fù)已插入數(shù)據(jù)(直接使用字段名稱),也可以獲取重復(fù)待插入數(shù)據(jù)(values(字段名稱))。我們不會對重復(fù)待插入數(shù)據(jù)進(jìn)行插入操作。

重復(fù)已插入數(shù)據(jù):上例中的(1,'yoona',20)

重復(fù)待插入數(shù)據(jù):上例中的(1,'yoona',25)

到此這篇關(guān)于詳解MySQL主鍵唯一鍵重復(fù)插入解決方法的文章就介紹到這了,更多相關(guān)MySQL主鍵唯一鍵重復(fù)插入內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Mysql避免重復(fù)插入數(shù)據(jù)的4種方式
  • 防止MySQL重復(fù)插入數(shù)據(jù)的三種方法
  • MySql三種避免重復(fù)插入數(shù)據(jù)的方法
  • mysql 存儲過程判斷重復(fù)的不插入數(shù)據(jù)
  • 分享MYSQL插入數(shù)據(jù)時忽略重復(fù)數(shù)據(jù)的方法
  • MySql避免重復(fù)插入記錄的幾種方法
  • MYSQL插入處理重復(fù)鍵值的幾種方法

標(biāo)簽:邯鄲 七臺河 無錫 汕尾 來賓 營口 西寧 寶雞

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解MySQL主鍵唯一鍵重復(fù)插入解決方法》,本文關(guān)鍵詞  詳解,MySQL,主鍵,唯,一鍵,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解MySQL主鍵唯一鍵重復(fù)插入解決方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解MySQL主鍵唯一鍵重復(fù)插入解決方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    泸西县| 连州市| 新宁县| 阿拉尔市| 吉木乃县| 洪洞县| 南召县| 西昌市| 全州县| 青田县| 平定县| 特克斯县| 红桥区| 景德镇市| 兴隆县| 东阿县| 平定县| 遂平县| 黄陵县| 徐汇区| 孝感市| 刚察县| 于都县| 保康县| 揭西县| 普宁市| 丹凤县| 刚察县| 吴川市| 双峰县| 双流县| 烟台市| 连江县| 嫩江县| 英吉沙县| 万宁市| 安阳市| 固镇县| 平乐县| 泸州市| 华坪县|