中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MYSQL中怎么插入處理重復鍵值

發布時間:2021-07-26 16:36:49 來源:億速云 閱讀:185 作者:Leah 欄目:數據庫

MYSQL中怎么插入處理重復鍵值,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

當unique列在一個UNIQUE鍵上插入包含重復值的記錄時,默認insert的時候會報1062錯誤,MYSQL有三種不同的處理方法,下面我們分別介紹。

先建立2個測試表,在id列上創建unique約束。
mysql> create table test1(id int,name varchar(5),type int,primary key(id));
Query OK, 0 rows affected (0.01 sec)

mysql> create table test2(id int,name varchar(5),type int,primary key(id));
Query OK, 0 rows affected (0.01 sec)


mysql> select * from test1;
+-----+------+------+
| id  | name | type |
+-----+------+------+
| 101 | aaa  |    1 | 
| 102 | bbb  |    2 | 
| 103 | ccc  |    3 | 
+-----+------+------+
3 rows in set (0.00 sec)

mysql> select * from test2;
+-----+------+------+
| id  | name | type |
+-----+------+------+
| 201 | aaa  |    1 | 
| 202 | bbb  |    2 | 
| 203 | ccc  |    3 | 
| 101 | xxx  |    5 | 
+-----+------+------+
4 rows in set (0.00 sec)

1、REPLACE INTO
發現重復的先刪除再插入,如果記錄有多個字段,在插入的時候如果有的字段沒有賦值,那么新插入的記錄這些字段為空。
mysql> replace into test1(id,name)(select id,name from test2);
Query OK, 5 rows affected (0.04 sec)
Records: 4  Duplicates: 1  Warnings: 0

mysql> select * from test1;
+-----+------+------+
| id  | name | type |
+-----+------+------+
| 101 | xxx  | NULL | 
| 102 | bbb  |    2 | 
| 103 | ccc  |    3 | 
| 201 | aaa  | NULL | 
| 202 | bbb  | NULL | 
| 203 | ccc  | NULL | 
+-----+------+------+
6 rows in set (0.00 sec)

需要注意的是,當你replace的時候,如果被插入的表如果沒有指定列,會用NULL表示,而不是這個表原來的內容。如果插入的內容列和被插入的表列一樣,則不會出現NULL。例如
mysql> replace into test1(id,name,type)(select id,name,type from test2);
Query OK, 8 rows affected (0.04 sec)
Records: 4  Duplicates: 4  Warnings: 0

mysql> select * from test1;
+-----+------+------+
| id  | name | type |
+-----+------+------+
| 101 | xxx  |    5 | 
| 102 | bbb  |    2 | 
| 103 | ccc  |    3 | 
| 201 | aaa  |    1 | 
| 202 | bbb  |    2 | 
| 203 | ccc  |    3 | 
+-----+------+------+
6 rows in set (0.00 sec)

如果INSERT的時候,需要保留被插入表的列,只更新指定列,那么就可以使用第二種方法。

2、INSERT INTO ON DUPLICATE KEY UPDATE
發現重復的是更新操作。在原有記錄基礎上,更新指定字段內容,其它字段內容保留。例如我只想插入test2表的id,name字段,但是要保留test1表的type字段:
mysql> insert into test1(id,name,type)(select id,name,type from test2) on DUPLICATE KEY UPDATE test1.name=test2.name;
Query OK, 5 rows affected (0.04 sec)
Records: 4  Duplicates: 1  Warnings: 0

mysql> select * from test1;
+-----+------+------+
| id  | name | type |
+-----+------+------+
| 101 | xxx  |    1 | 
| 102 | bbb  |    2 | 
| 103 | ccc  |    3 | 
| 203 | ccc  |    3 | 
| 202 | bbb  |    2 | 
| 201 | aaa  |    1 | 
+-----+------+------+
6 rows in set (0.00 sec)

如果INSERT的時候,只想插入原表沒有的數據,那么可以使用第三種方法。

3、IGNORE INTO
判斷是否存在,存在不插入,否則插入。很容易理解,當插入的時候,違反唯一性約束,MySQL不會嘗試去執行這條語句。例如:
mysql> insert ignore into test1(id,name,type)(select id,name,type from test2);
Query OK, 3 rows affected (0.01 sec)
Records: 4  Duplicates: 1  Warnings: 0

mysql> select * from test1;
+-----+------+------+
| id  | name | type |
+-----+------+------+
| 101 | aaa  |    1 | 
| 102 | bbb  |    2 | 
| 103 | ccc  |    3 | 
| 203 | ccc  |    3 | 
| 202 | bbb  |    2 | 
| 201 | aaa  |    1 | 
+-----+------+------+

6 rows in set (0.00 sec)

關于MYSQL中怎么插入處理重復鍵值問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

特克斯县| 会同县| 绵竹市| 阿拉善右旗| 渝北区| 嵊州市| 崇文区| 黄冈市| 宁河县| 万年县| 榆林市| 桓台县| 绥阳县| 新竹市| 唐海县| 家居| 临朐县| 博乐市| 辽源市| 巴东县| 筠连县| 澄江县| 望城县| 盘山县| 齐齐哈尔市| 寿光市| 佛冈县| 新宁县| 屯留县| 合水县| 渑池县| 赤峰市| 芒康县| 宜章县| 娄烦县| 澄江县| 五台县| 西昌市| 论坛| 莱西市| 札达县|