spring事務原理

四大特性:ACID

  • 原子性:
    一個事務的所有系列操作步驟被看成是一個動作,所有的步驟要麼全部完成要麼一個也不會完成,如果事務過程中任何一點失敗,將要被改變的數據庫記錄就不會被真正被改變。
  • 一致性:
    數據庫的約束級聯和觸發機制Trigger都必須滿足事務的一致性。也就是說,通過各種途徑包括外鍵約束等任何寫入數據庫的數據都是有效的,不能發生表與表之間存在外鍵約束,但是有數據卻違背這種約束性。所有改變數據庫數據的動作事務必須完成,沒有事務會創建一個無效數據狀態,這是不同於CAP理論的一致性”consistency”.
  • 隔離性:
    主要用於實現併發控制,隔離能夠確保併發執行的事務能夠順序一個接一個執行,通過隔離,一個未完成事務不會影響另外一個未完成事務。
  • 持久性:
    一旦一個事務被提交,它應該持久保存,不會因爲和其他操作衝突而取消這個事務。很多人認爲這意味着事務是持久在磁盤上,但是規範沒有特別定義這點。

傳播行爲

當事務方法被另一個事務方法調用時,必須指定事務應該如何傳播。例如:方法可能繼續在現有事務中運行,也可能開啓一個新事務,並在自己的事務中運行。

Spring 定義了七種傳播行爲:

PROPAGATION_REQUIRED 表示當前方法必須運行在事務中。如果當前事務存在,方法將會在該事務中運行。否則,會啓動一個新的事務,Spring 默認使用
PROPAGATION_SUPPORTS 表示當前方法不需要事務上下文,但是如果存在當前事務的話,那麼該方法會在這個事務中運行
PROPAGATION_MANDATORY 表示該方法必須在事務中運行,如果當前事務不存在,則會拋出一個異常
PROPAGATION_REQUIRED_NEW 表示當前方法必須運行在它自己的事務中。一個新的事務將被啓動。如果存在當前事務,在該方法執行期間,當前事務會被掛起。如果使用 JTATransactionManager 的話,則需要訪問 TransactionManager
PROPAGATION_NOT_SUPPORTED 表示該方法不應該運行在事務中。如果存在當前事務,在該方法運行期間,當前事務將被掛起。如果使用 JTATransactionManager 的話,則需要訪問 TransactionManager
PROPAGATION_NEVER 表示當前方法不應該運行在事務上下文中。如果當前正有一個事務在運行,則會拋出異常
PROPAGATION_NESTED 表示如果當前已經存在一個事務,那麼該方法將會在嵌套事務中運行。嵌套的事務可以獨立於當前事務進行單獨地提交或回滾。如果當前事務不存在,那麼其行爲與
PROPAGATION_REQUIRED 一樣。注意各廠商對這種傳播行爲的支持是有所差異的。可以參考資源管理器的文檔來確認它們是否支持嵌套事務

隔離級別

隔離級別 隔離級別的值 導致的問題
Read-Uncommitted 0 導致髒讀
Read-Committed 1 避免髒讀,允許不可重複讀和幻讀
Repeatable-Read 2 避免髒讀,不可重複讀,允許幻讀
Serializable 3 串行化讀,事務只能一個一個執行,避免了髒讀、不可重複讀、幻讀。執行效率慢,使用時慎重

髒讀:一事務對數據進行了增刪改,但未提交,另一事務可以讀取到未提交的數據。如果第一個事務這時候回滾了,那麼第二個事務就讀到了髒數據。
不可重複讀:一個事務中發生了兩次讀操作,第一次讀操作和第二次操作之間,另外一個事務對數據進行了修改,這時候兩次讀取的數據是不一致的。
幻讀:第一個事務對一定範圍的數據進行批量修改,第二個事務在這個範圍增加一條數據,這時候第一個事務就會丟失對新增數據的修改。
總結:
隔離級別越高,越能保證數據的完整性和一致性,但是對併發性能的影響也越大。
大多數的數據庫默認隔離級別爲 Read Commited,比如 SqlServer、Oracle
少數數據庫默認隔離級別爲:Repeatable Read 比如: MySQL InnoDB

屬性說明 @Transactional

a、isolation:用於指定事務的隔離級別。默認爲底層事務的隔離級別。
b、noRollbackFor:指定遇到指定異常時強制不回滾事務。
c、noRollbackForClassName:指定遇到指定多個異常時強制不回滾事務。該屬性可以指定多個異常類名。
d、propagation:指定事務的傳播屬性。
e、readOnly:指定事務是否只讀。表示這個事務只讀取數據但不更新數據,這樣可以幫助數據庫引擎優化事務。若真的是一個只讀取的數據庫應設置 readOnly=true
f、rollbackFor:指定遇到指定異常時強制回滾事務。
g、rollbackForClassName:指定遇到指定多個異常時強制回滾事務。該屬性可以指定多個異常類名。
h、timeout:指定事務的超時時長。

發佈了32 篇原創文章 · 獲贊 26 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章