MySQL ON DUPLICATE KEY UPDATE影响行数

目录

分析为什么Updates返回7

总结


数据库更新日志如下

java 复制代码
insertOrUpdateList|==>  Preparing: INSERT INTO clue_user_tag (vuid, tag_id, tag_type, content) VALUES (?, ?, ?, ?) , (?, ?, ?, ?) , (?, ?, ?, ?) , (?, ?, ?, ?) ON DUPLICATE KEY UPDATE content = VALUES(content) 
insertOrUpdateList|==> Parameters: 199603942960332807(Long), MI0101(String), org(String), {"buyCount":24,"realAmount":631000.49}(String), 199603942960332807(Long), 8802(String), spu(String), {"latestPurchaseTime":1733760202}(String), 199603942960332807(Long), 9380(String), spu(String), {"latestPurchaseTime":1733760202}(String), 199603942960332807(Long), 4456(String), spu(String), {"latestPurchaseTime":1733760202}(String)
insertOrUpdateList|<==    Updates: 7

可以看到,updateList,大小为4,但是影响行数返回了7

分析为什么Updates返回7

在MyBatis中,<insert>标签的返回值是受影响的行数。对于ON DUPLICATE KEY UPDATE语句,MySQL会返回插入和更新的总行数。具体来说:

  1. 插入操作:
  • 如果一行数据被成功插入,MySQL会返回1。
  • 如果一行数据因为主键冲突而没有被插入,MySQL不会增加返回值。
  1. 更新操作:
  • 如果一行数据因为主键冲突而被更新,MySQL会返回2(1表示插入尝试,1表示更新操作)

在本例中,有4行数据尝试插入,是如下情况:

  • 第1、2、3行数据因为主键冲突而被更新,返回2,
  • 第4行数据被成功插入,返回1。
  • 总的受影响行数为:1 (插入) + 2 (更新) + 2 (更新) + 2 (更新) = 7

因此,Updates返回7表示总共有7个操作被执行,其中包括插入和更新操作。

总结

Updates返回结果表示在执行批量插入或更新操作时,总共有多少个操作被执行。这包括成功插入的行数和因为主键冲突而被更新的行数。具体来说,每次更新操作会被计为2(一次插入尝试和一次更新),而每次成功的插入操作会被计为1。

相关推荐
数据库小组8 小时前
MySQL 删库后怎么恢复?binlog2sql 之外,NineData 还能做什么
数据库·sql·mysql·安全·数据·ninedata·删库
九皇叔叔12 小时前
MySQL 8.0 测试库安装
数据库·mysql
码界筑梦坊13 小时前
356-基于Python的网易新闻数据分析系统
python·mysql·信息可视化·数据分析·django·vue·毕业设计
一只大袋鼠15 小时前
MyBatis 从入门到实战(二):代理 Dao 开发与多表关联查询
java·开发语言·数据库·mysql·mybatis
逻极17 小时前
MySQL 从入门到精通:一个老 DBA 的实战心法
运维·数据库·mysql·从入门到精通·mysql从入门到精通
xuhaoyu_cpp_java17 小时前
事务学习(一)
数据库·经验分享·笔记·学习·mysql
最好的期待,未来可期18 小时前
MySQL语法的高级用法CASE WHEN
数据库·mysql
小陈工19 小时前
python Web开发从入门到精通(二十七)微服务架构设计原则深度解析:告别拆分烦恼,掌握治理精髓(下)
后端·python·mysql
1368木林森20 小时前
聊聊Mysql主从延迟的幽灵陷阱与解决方案
数据库·mysql
雪碧聊技术21 小时前
mysql表级锁的介绍
数据库·mysql