ibatis中SqlMapClient事务处理

来源:互联网 发布:颓废 知乎 编辑:程序博客网 时间:2024/04/28 11:21

        ibatis中SqlMapClient事务 sqlMapClient.startTransaction(); 开始事务sqlMapClient.commitTransaction(); 提交事务sqlMapClient.endTransaction(); 结束事务,操作失败的时候,整个事务就会在endTransaction时回滚。

       新版的ibatis中,不再有rollbackTransaction方法,只能选择endTransaction代替。如果代码没有显式的调用SqlMapClient.startTransaction()方法,则ibatis会将当前的数据库操作视为自动提交模式(AutoCommit=true),不过,值得注意的是,这里的所谓“自动判定”,实际上ibatis并没有去检查当前是否已经有事务开启。

    实际上,在执行update语句时,sqlMap会检查当前的Session是否已经关联了某个数据库连接,如果没有,则取一个数据库连接,将其AutoCommit属性设为true,然后执行update 操作,执行完之后又将这个连接释放。这样,上面两次update 操作实际上先后获取了两个数据库连接,而不是我们通常所认为的两次update 操作都基于同一个JDBC Connection。这点在开发时需特别注意。

        对于多条SQL 组合而成的一个JDBC 事务操作而言,必须使用startTransaction、commitTransaction和endTransaction操作以实现整体事务的原子性。

        注意!事务不能嵌套。在调用commit或end方法之前,从同一线程多次调用startTransaction将引起抛出例外。换句话说,对于每个SqlMap实例,每个线程最多只能打开一个事务。

0 0