關於Spring事務回滾的問題

weixin_34119545發表於2016-10-12

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. }  

相關文章