mysql中insert ignore、insert和replace的區(qū)別及說明
insert ignore、insert和replace的區(qū)別
| 指令 | 已存在 | 不存在 | 舉例 |
|---|---|---|---|
| insert | 報錯 | 插入 | insert into names(name, age) values(“小明”, 23); |
| insert ignore | 忽略 | 插入 | insert ignore into names(name, age) values(“小明”, 24); |
| replace | 替換 | 插入 | replace into names(name, age) values(“小明”, 25); |
表要求:有PrimaryKey,或者unique索引
結(jié)果:表id都會自增
測試代碼
創(chuàng)建表
CREATE TABLE names( ? ? id INT(10) PRIMARY KEY AUTO_INCREMENT, ? ? name VARCHAR(255) UNIQUE, ? ? age INT(10) )
插入數(shù)據(jù)
mysql> insert into names(name, age) values("小明", 24);
mysql> insert into names(name, age) values("大紅", 24);
mysql> insert into names(name, age) values("大壯", 24);
mysql> insert into names(name, age) values("秀英", 24);
mysql> select * from names;
+----+--------+------+
| id | name ? | age ?|
+----+--------+------+
| ?1 | 小明 ? | ? 24 |
| ?2 | 大紅 ? | ? 24 |
| ?3 | 大壯 ? | ? 24 |
| ?4 | 秀英 ? | ? 24 |
+----+--------+------+insert
插入已存在, id會自增,但是插入不成功,會報錯
mysql> insert into names(name, age) values("小明", 23);
ERROR 1062 (23000): Duplicate entry '小明' for key 'name'replace
已存在替換,刪除原來的記錄,添加新的記錄
mysql> replace into names(name, age) values("小明", 23);
Query OK, 2 rows affected (0.00 sec)
mysql> select * from names;
+----+--------+------+
| id | name ? | age ?|
+----+--------+------+
| ?2 | 大紅 ? | ? 24 |
| ?3 | 大壯 ? | ? 24 |
| ?4 | 秀英 ? | ? 24 |
| ?6 | 小明 ? | ? 23 |
+----+--------+------+不存在替換,添加新的記錄
mysql> replace into names(name, age) values("大名", 23);
Query OK, 1 row affected (0.00 sec)
mysql> select * from names;
+----+--------+------+
| id | name ? | age ?|
+----+--------+------+
| ?2 | 大紅 ? | ? 24 |
| ?3 | 大壯 ? | ? 24 |
| ?4 | 秀英 ? | ? 24 |
| ?6 | 小明 ? | ? 23 |
| ?7 | 大名 ? | ? 23 |
+----+--------+------+insert ignore
插入已存在,忽略新插入的記錄,id會自增,不會報錯
mysql> insert ignore into names(name, age) values("大壯", 25);
Query OK, 0 rows affected, 1 warning (0.00 sec)插入不存在,添加新的記錄
mysql> insert ignore into names(name, age) values("壯壯", 25);
Query OK, 1 row affected (0.01 sec)
mysql> select * from ?names;
+----+--------+------+
| id | name ? | age ?|
+----+--------+------+
| ?2 | 大紅 ? | ? 24 |
| ?3 | 大壯 ? | ? 24 |
| ?4 | 秀英 ? | ? 24 |
| ?6 | 小明 ? | ? 23 |
| ?7 | 大名 ? | ? 23 |
| 10 | 壯壯 ? | ? 25 |
+----+--------+------+以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySql,MVCC實(shí)現(xiàn)及其機(jī)制,快照讀在RC,RR下的區(qū)別說明
這篇文章主要介紹了MySql,MVCC實(shí)現(xiàn)及其機(jī)制,快照讀在RC,RR下的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
MySql5.6使用validate password 插件加強(qiáng)密碼強(qiáng)度的安裝及使用方法
在mysql5.6中使用validate password插件加強(qiáng)密碼強(qiáng)度,支持密碼的強(qiáng)度要求,是一款非常好用的密碼加強(qiáng)插件,下面小編通過本文給大家介紹MySql5.6使用validate password 插件加強(qiáng)密碼強(qiáng)度的安裝及使用方法,小伙伴們一起學(xué)習(xí)吧2016-07-07
詳解如何利用Xtrabackup進(jìn)行mysql增量備份
這篇文章主要為大家介紹了如何利用Xtrabackup進(jìn)行mysql增量備份詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
SQL Server 2005 安裝遇到的錯誤提示和解決方法
在安裝SQL Server 2005時有時會出現(xiàn)意想不到的問題,如IIS,性能計數(shù)器,OWC11,無法配置外圍應(yīng)用的問題,下面筆者分享一下在安裝SQL Server 2005時常見問題解決方法2014-01-01
關(guān)于MySQL innodb_autoinc_lock_mode介紹
下面小編就為大家?guī)硪黄P(guān)于MySQL innodb_autoinc_lock_mode介紹。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03
Mysql inner join on的用法實(shí)例(必看)
下面小編就為大家?guī)硪黄狹ysql inner join on的用法實(shí)例(必看)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03
mysql創(chuàng)建外鍵報錯的原因及解決(can't?not?create?table)
這篇文章主要介紹了mysql創(chuàng)建外鍵報錯的原因及解決方案(can't?not?create?table),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09

