Spring @

Spring事务的传播行为

在service类前加上@Transactional,声明这个service所有方法需要事务管理。每一个业务方法开始时都会打开一个事务。

Spring默认情况下会对运行期例外(RunTimeException)进行事务回滚。这个例外是unchecked

如果遇到checked意外就不回滚。

如何改变默认规则:

1 让checked例外也回滚:在整个方法前加上 @Transactional(rollbackFor=Exception.class)

2 让unchecked例外不回滚: @Transactional(notRollbackFor=RunTimeException.class)

3 不需要事务管理的(只查询的)方法:@Transactional(propagation=Propagation.NOT_SUPPORTED)

 

注意: 如果异常被try{}catch{}了,事务就不回滚了,如果想让事务回滚必须再往外抛try{}catch{throw Exception}。

扫描二维码关注公众号,回复: 562965 查看本文章

spring——@Transactional事务不管理jdbc,所以要自己把jdbc事务回滚。

下面给出了回滚JDBC事务的代码示例:

Java代码
  1. public void processT(String orders) {   
  2. Context initCtx = new InitialContext();   
  3. javax.sql.DataSource ds = javax.sql.DataSource)initCtx.lookup   
  4. (“java:comp/env/jdbc/OrdersDB”);   
  5. java.sql.Connection conn = ds.getConnection();   
  6. try {   
  7. conn.setAutoCommit( false ); //更改JDBC事务的默认提交方式   
  8. orderNo = createOrder( orders );   
  9. updateOrderStatus(orderNo, “orders created”);   
  10. conn.commit(); //提交JDBC事务   
  11. } catch ( Exception e ){   
  12. try {   
  13. conn.rollback(); //回滚sJDBC事务   
  14. throw new EJBException(“事务回滚: “ + e.getMessage());   
  15. } catch ( SQLException sqle ){   
  16. throw new EJBException(“出现SQL操作错误: “ + sqle.getMessage());   
  17. }   
  18. }   
  19. }  
[java] view plaincopy
 
  1. public void processT(String orders) {  
  2. Context initCtx = new InitialContext();  
  3. javax.sql.DataSource ds = javax.sql.DataSource)initCtx.lookup  
  4. (“java:comp/env/jdbc/OrdersDB”);  
  5. java.sql.Connection conn = ds.getConnection();  
  6. try{  
  7. conn.setAutoCommit( false ); //更改JDBC事务的默认提交方式  
  8. orderNo = createOrder( orders );  
  9. updateOrderStatus(orderNo, “orders created”);  
  10. conn.commit();//提交JDBC事务  
  11. }catch( Exception e ){  
  12. try{  
  13. conn.rollback();//回滚sJDBC事务  
  14. throw new EJBException(“事务回滚: “ + e.getMessage());  
  15. }catch( SQLException sqle ){  
  16. throw new EJBException(“出现SQL操作错误: “ + sqle.getMessage());  
  17. }  
  18. }  
  19. }

各种属性的意义:

    @Transactional(propagation=Propagation.NOT_SUPPORTED,readOnly=true),这样就做成一个只读事务,可以提高效率。

    REQUIRED:业务方法需要在一个容器里运行。如果方法运行时,已经处在一个事务中,那么加入到这个事务,否则自己新建一个新的事务。

       NOT_SUPPORTED:声明方法不需要事务。如果方法没有关联到一个事务,容器不会为他开启事务,如果方法在一个事务中被调用,该事务会被挂起,调用结束后,原先的事务会恢复执行。

       REQUIRESNEW:不管是否存在事务,该方法总汇为自己发起一个新的事务。如果方法已经运行在一个事务中,则原有事务挂起,新的事务被创建。

       MANDATORY:该方法只能在一个已经存在的事务中执行,业务方法不能发起自己的事务。如果在没有事务的环境下被调用,容器抛出例外。

       SUPPORTS:该方法在某个事务范围内被调用,则方法成为该事务的一部分。如果方法在该事务范围外被调用,该方法就在没有事务的环境下执行。

       NEVER:该方法绝对不能在事务范围内执行。如果在就抛例外。只有该方法没有关联到任何事务,才正常执行。

       NESTED:如果一个活动的事务存在,则运行在一个嵌套的事务中。如果没有活动事务,则按REQUIRED属性执行。它使用了一个单独的事务,这个事务 拥有多个可以回滚的保存点。内部事务的回滚不会对外部事务造成影响。它只对DataSourceTransactionManager事务管理器起效。

猜你喜欢

转载自ailikes.iteye.com/blog/2001335