原生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​​​​​​​

相关推荐
jiayou647 小时前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北8 小时前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤1 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12022 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip