mybatis mysql 批量update返回值 mybatis update返回条数

您所在的位置:网站首页 mybatis批量更新返回值问题 mybatis mysql 批量update返回值 mybatis update返回条数

mybatis mysql 批量update返回值 mybatis update返回条数

2024-05-05 07:26| 来源: 网络整理| 查看: 265

需求:笔者最近有一个需求是这样的,每个机柜每1分钟都会发一个心跳包,这个心跳包的数据如果和mysql数据库存在的数据一样,那么就不要更新了,直接给我返回一个0,我会根据这个0判断要不要存入这个心跳日志.也就是说.如果你这个表更新了,那么我就在另外一个表插入一个记录(异常记录).

问题:(这里指的是一条更新,非批量更新)mysql的更新如果相同,那么确实是返回一个0的,但是mybatis不知道为何总是返回一个1

过程:笔者查阅了资料,了解如下:

1:不同的数据库,update的机制是不一样的.但是针对标准SQL,不涉及具体数据库去更新一条数据,肯定是会操作一条记录,那么它会返回的是操作记录数,这个肯定是1.但是如果是受影响行数或者响应条数那么就是0了

2:使用mbatis更新数据时如果更新的数据相同,会返回1 ,在使用navicat客户端时,如果数据相同,返回值为0

3:Found MySQL specific workaround. If someone is curious - useAffectedRows option for jdbc url, e.g. 

解释:useAffectedRows的含义 :是否用受影响的行数替代查找到的行数来返回数据,也就是查找到了 但却不一定真正修改了 JDBC默认返回的是符合的行数Rows matched, 如果想返回修改过( Changed)的行数  ,需要使用useAffectedRows参数

也就是配置jdbc连接:jdbc:mysql://${jdbc.host}/${jdbc.db}?useAffectedRows=true

解决:jdbc.url=jdbc:mysql://localhost:xxxx/mlfdb_test?characterEncoding=utf8&useAffectedRows=true

扩展部分:其它配置参数

UsePerformanceMonitor,userperfmon, perfmon:是否启用性能监视,默认 false

IgnorePrepare:    是否忽略 Prepare() 调用,默认 true

UseProcedureBodies,procedure bodies:是否检查存储过程体、参数的有效性,默认 true

AutoEnlist:    是否自动使用活动的连接,默认 true

TreatTinyAsBoolean:是否将 TINYINT(1) 列视为布尔型,默认 true

AllowUserVariables:是否允许 SQL 中出现用户变量,默认 false

FunctionsReturnString:所有服务器函数是否按返回字符串处理,默认 false

UseAffectedRows:是否用受影响的行数替代查找到的行数来返回数据,默认 false

Keepalive:    保持 TCP 连接的秒数,默认0,不保持。

ConnectionLifeTime:连接被销毁前在连接池中保持的最少时间(秒)。默认 0

Pooling:    是否使用线程池,默认 true

MinimumPoolSize, min pool size:线程池中允许的最少线程数,默认 0

MaximumPoolSize,max pool size:线程池中允许的最多线程数,默认 100

ConnectionReset:连接过期后是否自动复位,默认 false

CharacterSet, charset:向服务器请求连接所使用的字符集,默认:无



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3