原生mysql与mybatis执行update语句的差异

在做一个解除绑定的接口中,发现了这个一个问题:

连续对接口进行测试,发现一直fan返回解除成功,但是逻辑上应该是解除之后,在解除它后就应该回显已解除绑定才对

就一直找原因,sql中使用的是mybatis的update进行的一个逻辑删除

然后将update的结果与0比较嘛,大于0,说明更改并影响了一条记录,则返回true

第二次执行update后,影响行数应该是0对吧,与0进行比较应该返回false,但是偏偏就是返回的true,说明什么,说明他有影响行,但是我使用原生的mysql写sql测试,影响行数就是为0.

至此我真是百思不得其解,反复地查找资料,最后终于找到了原因。

以下是我从这个博主的帖子找到的原因,写的很清楚。

重大补充 :最近发现update操作使用返回的的影响行数来判断操作成功与否,有时候还与第三方持久化框架有关

使用原生的sql(或者mysql) 重复请求update操作的时候,如 update test set cid = '5244';执行两次的时候发现,update返回影响行数为0

但是使用mybatis的时候,结果却不是这样的,执行两次的时候,发现update返回的影响行数始终是1。 spring + mybatis 方法 update 的返回值 默认:是 Rows matched 不是 rows affected(或者Changed)。后面跟踪发现,原来mybatis这个第三方持久化框架返回来的是被匹配的影响行数,所以返回的始终是1,那如果想要以返回的行数作为判断结果,需要在mybatis连接数据库的时候加上参数,

jdbc:mysql://{jdbc.host}/{jdbc.db}?useAffectedRows=true

获取matched行数

默认情况下,返回的就是matched 行数。也就是查询条件匹配的行数


mysql update 返回更新结果 sql更新并返回
https://blog.51cto.com/u_16099336/7307246​​​​​​​

相关推荐
Henry Zhu12328 分钟前
数据库:并发控制基本概念
服务器·数据库
银发控、1 小时前
数据库隔离级别与三个问题(脏读、不可重复读、幻读)
数据库·面试
爱可生开源社区1 小时前
MySQL 性能优化:真正重要的变量
数据库·mysql
ZeroNews内网穿透1 小时前
谷歌封杀OpenClaw背后:本地部署或是出路
运维·服务器·数据库·安全
~远在太平洋~1 小时前
Linux 基础命令
linux·服务器·数据库
小马爱打代码1 小时前
MySQL性能优化核心:InnoDB Buffer Pool 详解
数据库·mysql·性能优化
OceanBase数据库官方博客2 小时前
解析 OceanBase 生态工具链 —— OAT / obd / OCP / obshell
数据库·oceanbase·分布式数据库
Blockbuater_drug2 小时前
Peptide-Tools: 阿斯利康开源工具用于多肽性质预测-多肽等电点
数据库·pl·pichemist·peptide-tools·阿斯利康·多肽理化性质·等电点
数字护盾(和中)2 小时前
BAS+ATT&CK:企业主动防御的黄金组合
服务器·网络·数据库
micro_xx2 小时前
Matlab 有限元分析三维悬臂梁变形
前端·数据库·matlab