记录mysql ON DUPLICATE KEY UPDATE 时的小坑以及其底层处理逻辑

table 字段有**(id,column1,column2,column3)**
id 为主键
column1column2有复合唯一约束

xml 复制代码
	<insert id="xxx">
        INSERT INTO table (column1,column2,column3)
        VALUES
        <foreach collection="collection" item="i" separator=",">
            (#{i.column1}, #{i.column2}, #{i.column3})
        </foreach>
        AS new
        ON DUPLICATE KEY UPDATE
        column1 = new.column1, column2 = new.column3, column3= new.column3
    </insert>

这里插入一个已经存在的数据(只是column1column2 一样,column3 不一样)

报错:
Field 'id' doesn't have a default value

按理说column1column2 一样应该走更新操作,但是这里走的插入操作,参考了许多文章才知道原因,这里需要弄清楚使用ON DUPLICATE KEY UPDATEmysql的处理逻辑。

MySQL中的 INSERT INTO ... ON DUPLICATE KEY UPDATE 语句的执行逻辑是:

  1. 首先尝试执行插入操作
  2. 如果遇到主键/唯一键冲突,则执行更新操作
  3. 如果没有冲突,则插入成功

因为必须先执行了插入操作,然后我又没设置id值,所以报错了。

解决办法

我这里直接将id设置为了自增,这样就正常了。

总结

使用ON DUPLICATE KEY UPDATE时一定要注意表中的必填值,执行逻辑最先是插入操作,很容易报错。

相关推荐
大爱编程♡1 小时前
Spring IoC&DI
数据库·mysql·spring
周末吃鱼3 小时前
MySQL CTE:SQL查询新模式
数据库·sql·mysql
HL计算机菜鸟3 小时前
一对多的实现关系 在数据库表中多的一方添加字段,来关联一的一方主键
mysql
Psycho_MrZhang4 小时前
MySQL/PgSQL设计思想总结
数据库·mysql
风吹落叶花飘荡4 小时前
将mysql数据库的内容备份至阿里云 oss归档存储
数据库·mysql·阿里云
数据大魔方4 小时前
【期货量化入门】期权交易入门:从零开始学期权量化(TqSdk完整教程)
数据库·python·mysql·算法·区块链·程序员创富
w***95495 小时前
mysql之如何获知版本
数据库·mysql
q_19132846956 小时前
基于Springboo和vue开发的企业批量排班系统人脸识别考勤打卡系统
前端·javascript·vue.js·spring boot·mysql·毕业设计·人脸识别
风吹落叶花飘荡6 小时前
mysql数据库创建新用户,并只给其必要的权限
数据库·mysql
月度空间7 小时前
MySQL主从复制+Redis集群 数据库高可用实战教程(2024最新版)
mysql