javascript
框架:Spring事务的隔离级别
1. 首先,說說什么事務(Transaction)
事務,就是一組操作數(shù)據(jù)庫的動作集合。事務是現(xiàn)代數(shù)據(jù)庫理論中的核心概念之一。
如果一組處理步驟或者全部發(fā)生或者一步也不執(zhí)行,我們稱該組處理步驟為一個事務。
當所有的步驟像一個操作一樣被完整地執(zhí)行,我們稱該事務被提交。
由于其中的一部分或多步執(zhí)行失敗,導致沒有步驟被提交,則事務必須回滾到最初的系統(tǒng)狀態(tài)。
2. spring七個事務傳播屬性:
1.PROPAGATION_REQUIRED – 支持當前事務,如果當前沒有事務,就新建一個事務。這是最常見的選擇。
2.PROPAGATION_SUPPORTS – 支持當前事務,如果當前沒有事務,就以非事務方式執(zhí)行。
3.PROPAGATION_MANDATORY – 支持當前事務,如果當前沒有事務,就拋出異常。
4.PROPAGATION_REQUIRES_NEW – 新建事務,如果當前存在事務,把當前事務掛起。
5.PROPAGATION_NOT_SUPPORTED – 以非事務方式執(zhí)行操作,如果當前存在事務,就把當前事務掛起。
6.PROPAGATION_NEVER – 以非事務方式執(zhí)行,如果當前存在事務,則拋出異常。
7.PROPAGATION_NESTED – 如果當前存在事務,則在嵌套事務內(nèi)執(zhí)行。如果當前沒有事務,則進行與PROPAGATION_REQUIRED類似的操作。
備注:常用的兩個事務傳播屬性是1和4,即PROPAGATION_REQUIRED,PROPAGATION_REQUIRES_NEW
3. 五個隔離級別:
ISOLATION_DEFAULT?
這是一個PlatfromTransactionManager默認的隔離級別,使用數(shù)據(jù)庫默認的事務隔離級別.
另外四個與JDBC的隔離級別相對應;
ISOLATION_READ_UNCOMMITTED?
這是事務最低的隔離級別,它充許別外一個事務可以看到這個事務未提交的數(shù)據(jù)。?
這種隔離級別會產(chǎn)生臟讀,不可重復讀和幻像讀。
ISOLATION_READ_COMMITTED?
保證一個事務修改的數(shù)據(jù)提交后才能被另外一個事務讀取。另外一個事務不能讀取該事務未提交的數(shù)據(jù)。?
這種事務隔離級別可以避免臟讀出現(xiàn),但是可能會出現(xiàn)不可重復讀和幻像讀。
ISOLATION_REPEATABLE_READ?
這種事務隔離級別可以防止臟讀,不可重復讀。但是可能出現(xiàn)幻像讀。?
它除了保證一個事務不能讀取另一個事務未提交的數(shù)據(jù)外,還保證了避免下面的情況產(chǎn)生(不可重復讀)。
ISOLATION_SERIALIZABLE?
這是花費最高代價但是最可靠的事務隔離級別。事務被處理為順序執(zhí)行。?
除了防止臟讀,不可重復讀外,還避免了幻像讀。
關(guān)鍵詞:?
1)幻讀:事務1讀取記錄時事務2增加了記錄并提交,事務1再次讀取時可以看到事務2新增的記錄;?
2)不可重復讀取:事務1讀取記錄時,事務2更新了記錄并提交,事務1再次讀取時可以看到事務2修改后的記錄;?
3)臟讀:事務1更新了記錄,但沒有提交,事務2讀取了更新后的行,然后事務T1回滾,現(xiàn)在T2讀取無效。
臟讀:指一個事務讀取了一個未提交事務的數(shù)據(jù)
不可重復讀:在一個事務內(nèi)讀取表中的某一行數(shù)據(jù),多次讀取結(jié)果不同.一個事務讀取到了另一個事務提交后的數(shù)據(jù).
虛讀(幻讀):在一個事務內(nèi)讀取了別的事務插入的數(shù)據(jù),導致前后讀取不一致(insert)
?
總結(jié)
以上是生活随笔為你收集整理的框架:Spring事务的隔离级别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据库:redis和MySQL如何做到数
- 下一篇: redis:list的底层实现--压缩列