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

本文探讨了MyBatis中批量更新操作的执行器类型及其对返回结果的影响。详细介绍了SIMPLE、REUSE和BATCH三种执行器的区别,特别是BATCH执行器虽然能提高批量更新的性能,但无法获取update、delete操作返回的具体行数。文章最后提供了如何在mybatis-config.xml中配置以解决此问题的方法。

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



