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实例,每个线程最多只能打开一个事务。
- ibatis中SqlMapClient事务处理
- ibatis中SqlMapClient对象详解
- Ibatis中SqlMapClientTemplate和SqlMapClient的区别
- ibatis中SqlMapClientTemplate与SqlMapClient的区别
- Ibatis中SqlMapClientTemplate和SqlMapClient的区别
- IBatis--- 创建SqlMapClient
- iBatis SqlMapClient对象
- iBatis中的重要接口SqlMapClient
- ibatis之SqlMapClientTemplate和SqlMapClient
- iBatis中的重要接口SqlMapClient
- ibatis事务处理
- IBATIS事务处理
- IBATIS事务处理
- 通过ibatis的sqlmapclient获得connection连接
- Ibatis--SqlMapClient对象使用及事务(二)
- Ibatis--SqlMapClient对象使用及事务(三)
- Ibatis--SqlMapClient对象使用及事务(四)
- Ibatis,Spring注解方式注入sqlMapClient
- 第一题
- Sql Server根据条件将一列拆分成多列
- 第二题
- Tomcat并发优化,提高处理性能
- JVM GC垃圾回收算法
- ibatis中SqlMapClient事务处理
- MAC OS ShortCut Key
- LVS在大规模网络环境中的应用
- 自己写Java NIO服务器实例
- 第三题
- 一个简洁的线程安全,支持按日期切分,级别设置的log类
- Jquery1.6版本后attr的变化,灰常委屈
- 《深入理解计算机系统》读后笔记一
- python 微信企业号