transaction already active

来源:互联网 发布:上海软件协会网站 编辑:程序博客网 时间:2024/04/30 23:45

这个问题是使用spring 事务管理时经常出现的错误,最开始时相当令我头疼,也不知道是哪里出现的问题。在网上找了一阵后,依然无解。意思就是说上一个事务处于激活状态中,不能开始新的数据库更新操作。

 

开始事务的方法一般是这样的:

EntityTransaction txn = slavesDao.startTransaction();

   try {
    ...
    //slavesDao.delete(vsi) ;
    slavesDao.update(vsi) ;
    txn.commit();
    
   }catch (Exception e){
    txn.rollback();
    throw new Exception("delete Error: " + e.getMessage(), e);
   }

 

如果只是执行完了第一行语句,然后根本就没有执行到txn.commit();这一步,那么要开始下一个事务就会出这样的错,所以我们一般应该检查自己的逻辑是否正确!

原创粉丝点击