pring事務(Transaction)的七種事務傳播行爲及五種(數據庫四種)隔離級別

1. spring七個事務傳播屬性:

1.PROPAGATION_REQUIRED:支持當前事務,如果當前沒有事務,就新建一個事務。這是最常見的選擇。

2.PROPAGATION_SUPPORTS :支持當前事務,如果當前沒有事務,就以非事務方式執行。

3.PROPAGATION_MANDATORY :支持當前事務,如果當前沒有事務,就拋出異常。

4.PROPAGATION_REQUIRES_NEW :新建事務,如果當前存在事務,把當前事務掛起。

5.PROPAGATION_NOT_SUPPORTED:以非事務方式執行操作,如果當前存在事務,就把當前事務掛起。

6.PROPAGATION_NEVER:以非事務方式執行,如果當前存在事務,則拋出異常。

7.PROPAGATION_NESTED :如果當前存在事務,則在嵌套事務內執行。如果當前沒有事務,則進行與PROPAGATION_REQUIRED類似的操作。

 

2. 五種(數據庫四種)隔離級別:

ISOLATION_DEFAULT 
這是一個PlatfromTransactionManager默認的隔離級別,使用數據庫默認的事務隔離級別.

另外四個與JDBC的隔離級別相對應;

ISOLATION_READ_UNCOMMITTED 
這是事務最低的隔離級別,它充許別外一個事務可以看到這個事務未提交的數據。 
這種隔離級別會產生髒讀,不可重複讀和幻像讀。

ISOLATION_READ_COMMITTED 
保證一個事務修改的數據提交後才能被另外一個事務讀取。另外一個事務不能讀取該事務未提交的數據。 
這種事務隔離級別可以避免髒讀出現,但是可能會出現不可重複讀和幻像讀。

ISOLATION_REPEATABLE_READ 
這種事務隔離級別可以防止髒讀,不可重複讀。但是可能出現幻像讀。 
它除了保證一個事務不能讀取另一個事務未提交的數據外,還保證了避免下面的情況產生(不可重複讀)。

ISOLATION_SERIALIZABLE 
這是花費最高代價但是最可靠的事務隔離級別。事務被處理爲順序執行。 
除了防止髒讀,不可重複讀外,還避免了幻像讀。

關鍵詞: 
1、幻讀(虛讀):在一個事務內讀取了別的事務插入的數據,導致前後讀取不一致(insert); 
2、不可重複讀取:在一個事務內讀取表中的某一行數據,多次讀取結果不同.一個事務讀取到了另一個事務提交後的數據; 
3、髒讀:指一個事務讀取了一個未提交事務的數據。


 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章