需求:笔者最近有一个需求是这样的,每个机柜每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