mybatis mysql 批量update返回值 mybatis update返回条数 |
您所在的位置:网站首页 › mybatis批量更新返回值问题 › mybatis mysql 批量update返回值 mybatis update返回条数 |
需求:笔者最近有一个需求是这样的,每个机柜每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 |