• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL 处置插入过程中的主键唯一键重复值办法_mysql

mysql 搞代码 7年前 (2018-06-07) 279次浏览 已收录 0个评论

mysql 处理插入过程中的主键唯一键重复值办法

介绍

本篇文章主要介绍在插入数据到表中遇到键重复避免插入重复值的处理方法,主要涉及到IGNORE,ON DUPLICATE KEY UPDATE,REPLACE;接下来就分别看看这三种方式的处理办法。

IGNORE

使用ignore当插入的值遇到主键(PRIMARY KEY)或者唯一键(UNIQUE KEY)重复时自动忽略重复的记录行,不影响后面的记录行的插入,

创建测试表

CREATE  TABLE  Tignore (ID INT NOT NULL PRIMARY KEY , NAME1 INT )default charset=utf8;

MySQL 处置插入过程中的主键唯一键重复值办法_mysql

正常的插入如果插入的记录中存在键重复会报错,整个语句都会执行失败

MySQL 处置插入过程中的主键唯一键重复值办法_mysql

使用IGNORE如果插入的记录中存在重复值会忽略重复值的该记录行,不影响其它行的插入。

REPLACE

使用replace当插入的记录遇到主键或者唯一键重复时先删除表中重复的记录行再插入。

REPLACE   INTO Treplace() VALUES(1,1),(1,2),(2,2);

创建测试表

DROP TABLE  IF EXISTS Treplace; CREATE  TABLE  Treplace (ID INT NOT NULL PRIMARY KEY , NAME1 INT )default charset=utf8;

MySQL 处置插入过程中的主键唯一键重复值办法_mysql

 从输出的信息可以看到是4行受影响,说明它是先插入了(1,1)然后又删除了(1,1)

ON DUPLICATE KEY UPDATE

当插入的记录遇到主键或者唯一键重复时,会执行后面定义的UPDATE操作。

相当于先执行Insert 操作,再根据主键或者唯一键执行update操作。

创建测试表

DROP TABLE  IF EXISTS Tupdate; CREATE  TABLE  Tupdate (ID INT NOT NULL PRIMARY KEY , NAME1 INT UNIQUE KEY )default charset=utf8;

INSERT INTO Tupdate() VALUES(1,1),(1,2) ON DUPLICATE KEY UPDATE NAME1=NAME1+1; INSERT INTO Tupdate() VALUES(1,1),(1,2) ON DUPLICATE KEY UPDATE NAME1=VALUES(NAME1)+1;

第一条语句相当于执行:

INSERT INTO Tupdate() VALUES(1,1) UPDATE Tupdate SET NAME1=NAME1+1 WHERE ID=1;

第二条语句相当于执行:

INSERT INTO Tupdate() VALUES(1,1) UPDATE Tupdate SET NAME1=2+1 WHERE ID=1;

在ON DUPLICATE KEY UPDATE后面使用VALUES指的就是插入的记录的值,而不使用VALUES指的是表的自身值。

MySQL 处置插入过程中的主键唯一键重复值办法_mysql

注意: ON DUPLICATE KEY UPDATE的后面执行的UPDATE更新的记录是WHERE重复的主键或者唯一键的ID,这点非常重要。

比如下面这种情况:

INSERT INTO Tupdate() VALUES(1,1),(2,1) ON DUPLICATE KEY UPDATE NAME1=VALUES(ID)+1;

它是唯一键NAME1重复但是主键不重复,执行的语句是这样的:

INSERT INTO Tupdate() VALUES(1,1) UPDATE Tupdate SET NAME1=2+1 WHERE ID=1;

MySQL 处置插入过程中的主键唯一键重复值办法_mysql

不要认为会插入主键ID=2的记录进去。

总结

 上面的三种处理重复值的方法都支持标准的INSERT语法,包括INSERT INTO…VALUES, INSERT INTO ….SET ,INSERT INTO….. SELECT。

备注:

    作者:pursuer.chen

    博客:http://www.cnblogs.com/chenmh

本站点所有随笔都是原创,欢迎大家转载;但转载时必须注明文章来源,且在文章开头明显处给明链接。

《欢迎交流讨论》

2楼Nabulio
技术大神
1楼山鼠
高级技能,牛

欢迎大家阅读《MySQL 处置插入过程中的主键唯一键重复值办法_mysql》,跪求各位点评,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL 处置插入过程中的主键唯一键重复值办法_mysql

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址