MySQL 插入更新语句(insert…on duplicate key update语句 )

我们日常在使用 insert into 语句向表中插入数据时,一定遇到过主键或唯一索引冲突的情况,当遇到这种情况时,MySQL默认的反应是报错并停止执行后续的语句,为了避免这种情况,你有3种选择:

  • 使用insert ignore into语句忽略冲突语句并继续执行。
  • 使用replace into语句对冲突记录进行替换,用法见链接:MySQL 插入替换语句(replace into statement)
  • 使用insert...on duplicate key update语句对冲突记录进行更新。

文章目录

  • [一、insert ... on duplicate key update语句简介](#一、insert … on duplicate key update语句简介)
    • [1.1 基本用法](#1.1 基本用法)
    • [1.2 同时引用新旧值](#1.2 同时引用新旧值)

一、insert ... on duplicate key update语句简介

1.1 基本用法

创建一张测试表test,其中id为主键,并插入2条数据:

sql 复制代码
create table test(
id int not null auto_increment primary key,
source varchar(16),
val int,
conflict int);

truncate table test;
insert into test values(1,'insert',100,0),(2,'insert',200,0);
table test;

下面使用insert...on duplicate key update语句插入2条记录,其中id=1的记录将与原表中的记录产生主键冲突:

sql 复制代码
insert into test values(3,'insert_update',300,0),(1,'insert_update',400,1) 
on duplicate key update conflict=conflict+1; 
table test;

根据执行结果,可以看到on dupldate update语句存在下面特点:

  • 当不存在主键或唯一键冲突时,它就是普通的insert语句(id=3)。

  • 当存在主键或唯一键冲突时,它会插入失败,同时执行on duplicate update后的语句。

  • 成功插入时影响1行,出现冲突时影响2行,因此这里影响的数据行是3。

1.2 同时引用新旧值

insert...on update 语句最大的用处还是在出现冲突时,可以同时对新旧值进行引用,这意味着它非常适合需要累加的场景。

现在要求当出现ID冲突时将新旧的val值累加保存到表中,通过列名可以直接引用表中的旧值,而通过values(列名)可以引用即将插入的新值:

sql 复制代码
insert into test values(1,'insert_update',300,0) 
on duplicate key update conflict=conflict+1, val=val+values(val); 

除了使用values函数,还可以通过给新增的列取别名,并通过别名引用,例如将新插入的列取名为new,上面的语句可以改写为:

sql 复制代码
insert into test values(1,'insert_update',300,0) as new
on duplicate key update test.conflict=test.conflict+1, test.val=test.val+new.val; 

上面的语句中由于记录new默认和原表字段名相同,所以要通过前缀来区分新旧记录,你也直接给new的字段取不同的别名:

sql 复制代码
insert into test values(1,'insert_update',300,0) as new(a,b,c,d)
on duplicate key update conflict=conflict+1, val=val+c; 

以上即是insert...on update 语句的基本用法,结合insert ignore和replace into语句,你即可以在出现insert主键或唯一键冲突时根据需要选择合适的处理方案。

相关推荐
萧鼎9 分钟前
深度探索 Py2neo:用 Python 玩转图数据库 Neo4j
数据库·python·neo4j
m0_653031361 小时前
腾讯云认证考试报名 - TDSQL数据库交付运维专家(TCCE MySQL版)
运维·数据库·腾讯云
power 雀儿1 小时前
集群聊天服务器---MySQL数据库的建立
服务器·数据库·mysql
骑着王八撵玉兔3 小时前
【性能优化与架构调优(二)】高性能数据库设计与优化
数据库·性能优化·架构
Edingbrugh.南空3 小时前
Flink MySQL CDC 环境配置与验证
mysql·adb·flink
BD_Marathon4 小时前
Ubuntu:Mysql服务器
服务器·mysql·ubuntu
想要入门的程序猿4 小时前
Qt写入excel
数据库·qt·excel
Q_970956394 小时前
java+vue+SpringBoo校园失物招领网站(程序+数据库+报告+部署教程+答辩指导)
java·数据库·vue.js
Wyc724094 小时前
Maven
java·数据库·maven
程序猿小D4 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的电影小说网站管理系统,推荐!
java·数据库·mysql·spring·毕业设计·ssm框架·电影小说网站