码迷,mamicode.com
首页 > 数据库 > 详细

mysql执行update语句受影响行数是0

时间:2018-12-18 20:57:31      阅读:752      评论:0      收藏:0      [点我收藏+]

标签:数据   ted   coding   匹配   com   pre   6.2   mys   127.0.0.1   

mybatis连接mysql数据库,发现同一个update执行多次,返回的int值都是1。

我记得同样的update再次执行时 受影响行数是0。

后来发现,我之前一直用的SQLyog是这样子的。

原来,不同的连接客户端执行update给出的受影响行数不同。

技术分享图片

技术分享图片

技术分享图片

 

对于再次返回0,网上的资料是,MySQL 为了提升性能,当它发现要执行的修改内容与数据库中完全一致时,对它而言,此时修改是毫无意义的,反而会消耗一次执行修改的性能,于是它就不再做修改,因而受影响行数就是0。

 

至于mybatis,网上有说mybatis这个第三方持久化框架返回来的是被匹配的影响行数,所以返回的始终是1,那如果想要以返回的行数作为判断结果,需要在db连接串里使用useAffectedRows=true,即

jdbc:mysql://127.0.0.1:3306/cn_appoint?characterEncoding=utf-8&useAffectedRows=true

 

经初步测试,并不起作用,始终返回的还是1。执行select version();查看mysql版本:5.6.29-mycat-1.6-RELEASE-20161028204710

 

mysql执行update语句受影响行数是0

标签:数据   ted   coding   匹配   com   pre   6.2   mys   127.0.0.1   

原文地址:https://www.cnblogs.com/buguge/p/10139872.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!