mybatis之update返回响应条数/受影响行数(如果更新数据与原数据一致则返回0)

需求:笔者最近有一个需求是这样的,每个机柜每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:向服务器请求连接所使用的字符集,认:无

相关文章

Java中的String是不可变对象 在面向对象及函数编程语言中,不...
String, StringBuffer 和 StringBuilder 可变性 String不可变...
序列化:把对象转换为字节序列的过程称为对象的序列化. 反序...
先说结论,是对象!可以继续往下看 数组是不是对象 什么是对...
为什么浮点数 float 或 double 运算的时候会有精度丢失的风险...
面试题引入 这里引申出一个经典问题,看下面代码 Integer a ...