捕获异常,手动让Spring事务回滚

在spring的配置文件中,如果数据源的defaultAutoCommit设置为True了,那么方法中如果自己捕获了异常,事务是不会回滚的,如果没有自己捕获异常则事务会回滚,如下例
比如配置文件里有这么条记录:

[html]  view plain  copy
 print ?
  1. <bean id="dataSource" class="xxx">  
  2.    <property name="xxx" value="xxx"/>  
  3.    <property name="xxx" value="xxx"/>  
  4.                      ....  
  5.      <property name="defaultAutoCommit" value="true" />  
  6. bean>  

那么现在有两个情况
情况1:如果没有在程序中手动捕获异常

[java]  view plain  copy
 print ?
  1. @Transactional(rollbackFor = { Exception.class })  
  2. public void test() throws Exception {  
  3.      doDbStuff1();  
  4.      doDbStuff2();//假如这个操作数据库的方法会抛出异常,现在方法doDbStuff1()对数据库的操作   会回滚。  
  5. }  

情况2:如果在程序中自己捕获了异常

[java]  view plain  copy
 print ?
  1. @Transactional(rollbackFor = { Exception.class })  
  2. public void test() {  
  3.      try {  
  4.         doDbStuff1();  
  5.         doDbStuff2();//假如这个操作数据库的方法会抛出异常,现在方法doDbStuff1()对数据库的操作  不会回滚。  
  6.      } catch (Exception e) {  
  7.            e.printStackTrace();     
  8.      }  
  9. }  

现在如果我们需要手动捕获异常,并且也希望抛异常的时候能回滚肿么办呢?
下面这样写就好了,手动回滚事务:

[java]  view plain  copy
 print ?
  1. @Transactional(rollbackFor = { Exception.class })  
  2. public void test() {  
  3.      try {  
  4.         doDbStuff1();  
  5.         doDbStuff2();  
  6.      } catch (Exception e) {  
  7.           e.printStackTrace();     
  8.           TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();//就是这一句了,加上之后,如果doDbStuff2()抛了异常,                                                                                       //doDbStuff1()是会回滚的  
  9.      }  
  10. }  

你可能感兴趣的:(sql)