最近在ssm框架的项目中需要用到独立事务的实现,找了半天,搜集了以下理论知识为实现做准备。事务管理器为datasource
(1)Spring在transactiondefinition接口中规定了7种类型的事务传播行为,propagation开头,
1:required 如果没有事务,就新建一个事务,如果已经存在一个事务就加入到该事务中。这是最常见的选择。
2:supports 支持当前事务,如果没有则以非事务的方式执行
3: mandatory 使用当前事务,如果没有则抛出异常
4:requires_new 新建事务并挂起当前事务,需要使用jtaTransactionManager作为事务管理器(独立事务用这个)好像datasourceTransactionManager也可以用
5:not_supported 以非事务方式运行,挂起当前事务,需要使用jtaTransactionManager作为事务管理器
6:never 以非事务方式运行,如果存在事务则抛出异常
7:nested 如果一个活动的事务存在,则运行在一个嵌套的事务中.,如果没有当前事务类似于1required ,DataSourceTransactionManager使用savepoint支持 PROPAGATION_NESTED时,需要JDBC 3.0以上驱动及1.4以上的JDK版本支持,外层事务的回滚可以引起内层事务的回滚。而内层事务的异常并不会导致外层事务的回滚
在transactionManager事务管理器中定义了5个不同的事务隔离级别 isolution开头
1:default 默认使用数据库的隔离级别
2:read_uncommitted 允许其他事务可以看到当前事务未提交的数据,出现脏读、不可重复度和幻象读
3:read_committed 保证当前事务修改的数据提交后才可被其他事务毒素,不会出现脏读,会出现可重复度和幻象读 一般用这个即可
4:repeatable_read 可能出现幻像读
5:serializable 事务被处理为顺序执行,耗费了最大的资源
(3)内置事务管理器实现
Spring提供了许多内置事务管理器实现:
- DataSourceTransactionManager:位于org.springframework.jdbc.datasource包中,数据源事务管理器,提供对单个javax.sql.DataSource事务管理,用于Spring JDBC抽象框架、iBATIS或MyBatis框架的事务管理;
- JdoTransactionManager:位于org.springframework.orm.jdo包中,提供对单个javax.jdo.PersistenceManagerFactory事务管理,用于集成JDO框架时的事务管理;
- JpaTransactionManager:位于org.springframework.orm.jpa包中,提供对单个javax.persistence.EntityManagerFactory事务支持,用于集成JPA实现框架时的事务管理;
- HibernateTransactionManager:位于org.springframework.orm.hibernate3包中,提供对单个org.hibernate.SessionFactory事务支持,用于集成Hibernate框架时的事务管理;该事务管理器只支持Hibernate3+版本,且Spring3.0+版本只支持Hibernate 3.2+版本;
- JtaTransactionManager:位于org.springframework.transaction.jta包中,提供对分布式事务管理的支持,并将事务管理委托给Java EE应用服务器事务管理器;
- OC4JjtaTransactionManager:位于org.springframework.transaction.jta包中,Spring提供的对OC4J10.1.3+应用服务器事务管理器的适配器,此适配器用于对应用服务器提供的高级事务的支持;
- WebSphereUowTransactionManager:位于org.springframework.transaction.jta包中,Spring提供的对WebSphere 6.0+应用服务器事务管理器的适配器,此适配器用于对应用服务器提供的高级事务的支持;
- WebLogicJtaTransactionManager:位于org.springframework.transaction.jta包中,Spring提供的对WebLogic 8.1+应用服务器事务管理器的适配器,此适配器用于对应用服务器提供的高级事务的支持。
代码
DefaultTransactionDefinition def = new DefaultTransactionDefinition();
def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW);
//def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);
TransactionStatus status = transactionManagerTmp.getTransaction(def);//需要调用的方法,独立事务
ResultInfo returnResult = decpMsgServiceClient.createAndsendMessage(globalBusinessID, businessType, messageID, content);
transactionManagerTmp.commit(status); 手动提交独立事务