Java Spring 事務回溯詳解
spring 事務回滾
1、遇到的問題
當我們一個方法裡面有多個資料庫保存操作的時候,中間的資料庫操作發生的錯誤。偽代碼如下:
public method() { Dao1.save(Person1); Dao1.save(Person2); Dao1.save(Person2);//假如这句发生了错误,前面的两个对象会被保存到数据库中 Dao1.save(Person2); }
期待的情況:發生錯誤之前的所有資料庫保存操作都回滾,即不保存
正常情況:前面的資料庫操作會被執行,而發生資料庫操作錯誤開始及之後的所有的資料保存操作都將失敗。這樣子應該都不是我們要的結果吧。
當遇到這種情況,我們就可以使用Spring的事務來解決這個問題。
2、異常的一些基本知識
1) 異常的架構
異常的繼承結構:Throwable為基類,Error和Exception繼承Throwable,RuntimeException和IOException等繼承Exception。 Error和RuntimeException及其子類別成為未檢查異常(unchecked),其它異常成為已檢查異常(checked)。
2)Error異常
Error表示程式在運行期間出現了十分嚴重、不可恢復的錯誤,在這種情況下應用程式只能中止運行,例如JAVA 虛擬機出現錯誤。 Error是一種unchecked Exception,編譯器不會檢查Error是否被處理,在程式中不用捕獲Error類型的異常。一般情況下,程式中也不應該拋出Error類型的例外。
3)RuntimeException異常
Exception異常包括RuntimeException異常和其他非RuntimeException的異常。
RuntimeException 是一種Unchecked Exception,即表示編譯器不會檢查程式是否對RuntimeException作了處理,在程式中不必捕獲RuntimException類型的例外,也不必在方法體聲明拋出 RuntimeException類別。 RuntimeException發生的時候,表示程式中出現了程式錯誤,所以應該找出錯誤修改程序,而不是去捕獲RuntimeException。
4)Checked Exception異常
Checked Exception異常,這也是在編程中使用最多的Exception,所有繼承自Exception並且不是RuntimeException的異常都是checked Exception,上圖中的IOException和ClassNotFoundException的異常都是checked Exception,上圖中的IOException和ClassNotFoundException。 JAVA 語言規定必須對checked Exception作處理,編譯器會對此作檢查,要麼在方法體中宣告拋出checked Exception,要麼使用catch語句捕獲checked Exception進行處理,不然不能透過編譯。
3、實例
這裡使用的事務配置如下:
<!-- Jpa 事务配置 --> <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="entityManagerFactory"/> </bean> <!-- 开启注解事务 --> <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true" />
在spring的設定檔中,如果資料來源的defaultAutoCommit設定為True了,那麼方法中如果自己不會擷取了滾的,如果沒有自己捕獲異常則事務會回滾,如下例
比如配置文件裡有這麼條記錄
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="xxx" value="xxx"/> <property name="xxx" value="xxx"/> .... <property name="defaultAutoCommit" value="true" /> </bean>
可能你會發現你並沒有配置這個參數,是不是他就不會自動提交呢?答案是不是的,我這裡是使用了com.alibaba.druid.pool.DruidDataSource作為資料庫連接池,預設的defaultAutoCommit就是true,可以看下面的來源碼
那麼情況:如果沒有在程序中手動捕獲異常
@Transactional(rollbackOn = { Exception.class }) public void test() throws Exception { doDbStuff1(); doDbStuff2();//假如这个操作数据库的方法会抛出异常,现在方法doDbStuff1()对数据库的操作 会回滚。 }
@Transactional(rollbackOn = { Exception.class }) public void test() { try { doDbStuff1(); doDbStuff2();//假如这个操作数据库的方法会抛出异常,现在方法doDbStuff1()对数据库的操作 不会回滚。 } catch (Exception e) { e.printStackTrace(); } }
下面這樣寫就好了,手動回滾事務:
@Transactional(rollbackOn = { Exception.class }) public void test() { try { doDbStuff1(); doDbStuff2(); } catch (Exception e) { e.printStackTrace(); TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();//就是这一句了,加上之后,如果doDbStuff2()抛了异常, //doDbStuff1()是会回滚的 } }

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

公司安全軟件導致部分應用無法正常運行的排查與解決方法許多公司為了保障內部網絡安全,會部署安全軟件。 ...

系統對接中的字段映射處理在進行系統對接時,常常會遇到一個棘手的問題:如何將A系統的接口字段有效地映�...

在使用MyBatis-Plus或其他ORM框架進行數據庫操作時,經常需要根據實體類的屬性名構造查詢條件。如果每次都手動...

將姓名轉換為數字以實現排序的解決方案在許多應用場景中,用戶可能需要在群組中進行排序,尤其是在一個用...

在使用IntelliJIDEAUltimate版本啟動Spring...

Java對象與數組的轉換:深入探討強制類型轉換的風險與正確方法很多Java初學者會遇到將一個對象轉換成數組的�...

電商平台SKU和SPU表設計詳解本文將探討電商平台中SKU和SPU的數據庫設計問題,特別是如何處理用戶自定義銷售屬...

在使用TKMyBatis進行數據庫查詢時,如何優雅地獲取實體類變量名以構建查詢條件,是一個常見的難題。本文將針...
