1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > MySQL 处理插入过程中的主键唯一键重复值的操作【MySQL】

MySQL 处理插入过程中的主键唯一键重复值的操作【MySQL】

时间:2022-08-05 21:06:58

相关推荐

MySQL 处理插入过程中的主键唯一键重复值的操作【MySQL】

数据库|mysql教程

MySQL ,主键重复值

数据库-mysql教程

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

人人分销商城v2.8源码,vscode打开闪退,ubuntu系统音,tomcat 多项目,视频存储为sqlite文件,短信添加人插件,前端框架为什么诞生在美国,爬虫怎么爬要vip的,php 验证时间,铜陵seo有哪些,公司网站 php源代码,html网页不能向下滚动,html5网格布局模板lzw

IGNORE

精仿百度贴吧整站源码,vscode补全函数体,ubuntu关闭死机,tomcat安装详解,sqlite c 运行时,不需要写样式表的前端框架,如何根除卧室里的蚂蚁爬虫,数字签名 php,衢州seo优化报价,网站标签切换,手机视频播放器网页代码下载,今日头条网站模板lzw

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

夏日PHP注册登录源码,vscode相对路径,ubuntu run驱动,tomcat配置需要密码,免费爬虫盘,php网站结构图,seo怎么选择培训班,网站导航开源,货站模板lzw

创建测试表

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

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

使用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;

从输出的信息可以看到是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 TupdateSET NAME1=NAME1+1WHERE ID=1;

第二条语句相当于执行:

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

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

注意: 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 TupdateSET NAME1=2+1WHERE ID=1;

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

总结

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。