mybatis批量更新返回结果为-1,是由于mybatis的defaultExecutorType引起的,
它有三个执行器:SIMPLE 就是普通的执行器,也是默认的;REUSE 执行器会重用预处理语句(prepared statements); BATCH 执行器将重用语句并执行批量更新。
BATCH可以批量更新操作,缓存SQL以提高性能,缺陷就是无法获取update、delete返回的行数。
如果要拿到更新条数,要么把defaultExecutorType执行器的值改为SIMPLE或REUSE,如果修改排至则可参考如下:
在mybatis-config.xml配置:
<configuration>
<settings>
<setting name="defaultExecutorType" value="SIMPLE"/>
<setting name="defaultExecutorType" value="BATCH"/>
</settings>
</configuration>