mybatis update数据时无异常但没更新成功;update异常时如数据超出大小限制,造成死锁...

没更新的问题原因:

sqlSession.commit();

没执行commit,但官方文档里有这样的描述:“默认情况下 MyBatis 不会自动提交事务,除非它侦测到有插入、更新或删除操作改变了数据库。”  

源码:

<update id="updateTest" parameterType="cn.td.user.TestModel"> //TestModel是一个JavaBean
 update test_table set test_case_suc_num = #{test_case_suc_num} where test_name = #{test_name} </update>
    public void updateAllInfo(List<TestModel> list) throws IOException{     
        SqlSessionFactory sqlSessionFactory = getSqlFactory();
        SqlSession sqlSession = sqlSessionFactory.openSession();
        for(TestModel testModel : list){
            System.out.println(testModel);
            sqlSession.update("cn.td.dao.updatetest",testModel);
            sqlSession.commit();
        }
        sqlSession.close();
    }

 以上的java代码中update异常会造成  数据库死锁,导致下次无法正常更新。

死锁的概念就是类似git中的lock,操作残留 或者 互斥。

解决办法:

public void updateAllInfo(List<TestModel> list) throws IOException{
        SqlSessionFactory sqlSessionFactory = getSqlFactory();
        SqlSession sqlSession = sqlSessionFactory.openSession();
        for(TestModel testModel : list){
            System.out.println(testModel);

            try {
                sqlSession.update("cn.td.dao.updatetest",testModel);
            } catch (Exception e) {
                sqlSession.rollback();
                e.printStackTrace();
            }
            
            sqlSession.commit();
        }
        sqlSession.close();
    }

事务回滚。

转载于:https://www.cnblogs.com/dongzhuangdian/p/9446407.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值