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>
本文解析了MyBatis批量更新返回结果为-1的原因,这通常由BATCH执行器特性引起,因其不返回更新行数。文章提供了通过调整defaultExecutorType配置为SIMPLE或REUSE来获取更新条数的方法。
501

被折叠的 条评论
为什么被折叠?



