mybatis批量更新返回结果为-1,是由于mybatis的defaultExecutorType引起的,
它有三个执行器: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>