MyBatis-Generator插入删除数据返回-2147482646

在使用MyBatis-Generator自动生成的代码进行删除数据时( deleteByPrimaryKey 方法 )返回的int 值为 -2147482646 。正常的逻辑是成功删除返回 1 ,失败返回 0(未删除数据) ,特意去官网看了这个方法的说明,发现没有类似的说明(我没看到…)。

以下为其他网友的解决方案,还果然是这一原因。。以下内容为转载


作者:就算曾经遍体鳞伤也要相信明天
来源:CSDN
原文:https://blog.csdn.net/u010177899/article/details/68061303
版权声明:本文为博主原创文章,转载请附上博文链接!

MyBatis发现更新和插入返回值一直为"-2147482646"的错误是由defaultExecutorType设置引起的,如果设置为BATCH,更新返回值就会丢失。mybatis官方的讨论列表,这句很关键:

“If the BATCH executor is in use, the update counts are being lost. ”

在我的springMVC和mybatis整合中设置了如下内容

<!-- 配置mapper接口 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="*****.dao" />
</bean>
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
    <constructor-arg index="0" ref="sqlSessionFactory" />
    <constructor-arg index="1" value="BATCH" />
</bean>
<!-- 事务配置 -->
<bean id="transactionManager"
    class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource" />
</bean>

就是因为上面设置了

<constructor-arg index="1" value="BATCH" />

这句引起的。去掉即可。

由于框架是别人搭建的,不知道此处的设置是何用意。

<constructor-arg index="1" value="BATCH" />这是设置如此是想要进行批量操作,但是经测试没有此处的设置也可进行批量操作。大胆果断的删除即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值