zoukankan      html  css  js  c++  java
  • mysql执行update语句受影响行数是0

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

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

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

    原来,不同的连接客户端执行update给出的受影响行数不同。如下是navicat for mysql,JetBrains旗下的DataGrip, 小海豚 sqlyog。

    对于再次返回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-------------------------->【2019-12-9 11:30】有网友回复,所以又测了一下,发现这个useAffectedRows=true是好使的,同样的update,第一次执行返回1,第二次及之后执行时就会返回0。我是用SpringBoot集成baomidou的MybatisPlus测试的,mysql版本是5.7.28。

  • 相关阅读:
    使用PullToRefresh实现下拉刷新和上拉加载
    Java RandomAccessFile用法
    Java_io体系之RandomAccessFile简介、走进源码及示例——20
    获取Android设备唯一标识码
    MQTT协议简记
    ORMLite学习入门笔记
    service的生命周期
    android广播(内部类)使用
    intent 几种用法
    intent.setFlags方法中的参数值含义
  • 原文地址:https://www.cnblogs.com/buguge/p/10139872.html
Copyright © 2011-2022 走看看