數(shù)據(jù)庫(kù)有以下幾種并發(fā)問(wèn)題:
-
第一類更新丟失
image -
臟讀
image -
幻讀
image -
不可重復(fù)讀
image -
第二類更新丟失
image
數(shù)據(jù)庫(kù)事務(wù)隔離級(jí)別
1. READ_UNCOMMITED
- 事務(wù)對(duì)當(dāng)前被讀取的數(shù)據(jù)不加鎖;
- 事務(wù)在更新某數(shù)據(jù)的瞬間(就是發(fā)生更新的瞬間),必須先對(duì)其加 行級(jí)共享鎖,直到事務(wù)結(jié)束才釋放。
表現(xiàn):
- 事務(wù)1讀取某行記錄時(shí),事務(wù)2也能對(duì)這行記錄進(jìn)行讀取、更新;當(dāng)事務(wù)2對(duì)該記錄進(jìn)行更新時(shí),事務(wù)1再次讀取該記錄,能讀到事務(wù)2對(duì)該記錄的修改版本,即使該修改尚未被提交。
- 事務(wù)1更新某行記錄時(shí),事務(wù)2不能對(duì)這行記錄做更新,直到事務(wù)1結(jié)束。
2. READ_COMMITED
- 事務(wù)對(duì)當(dāng)前被讀取的數(shù)據(jù)加 行級(jí)共享鎖(當(dāng)讀到時(shí)才加鎖),一旦讀完該行,立即釋放該行級(jí)共享鎖;
- 事務(wù)在更新某數(shù)據(jù)的瞬間(就是發(fā)生更新的瞬間),必須先對(duì)其加 行級(jí)排他鎖,直到事務(wù)結(jié)束才釋放。
表現(xiàn):
- 事務(wù)1讀取某行記錄時(shí),事務(wù)2也能對(duì)這行記錄進(jìn)行讀取、更新;當(dāng)事務(wù)2對(duì)該記錄進(jìn)行更新時(shí),事務(wù)1再次讀取該記錄,讀到的只能是事務(wù)2對(duì)其更新前的版本,要不就是事務(wù)2提交后的版本。
- 事務(wù)1更新某行記錄時(shí),事務(wù)2不能對(duì)這行記錄做更新,直到事務(wù)1結(jié)束。
3. REPEATABLE READ
- 事務(wù)在讀取某數(shù)據(jù)的瞬間(就是開始讀取的瞬間),必須先對(duì)其加 行級(jí)共享鎖,直到事務(wù)結(jié)束才釋放;
- 事務(wù)在更新某數(shù)據(jù)的瞬間(就是發(fā)生更新的瞬間),必須先對(duì)其加 行級(jí)排他鎖,直到事務(wù)結(jié)束才釋放。
表現(xiàn):
- 事務(wù)1讀取某行記錄時(shí),事務(wù)2也能對(duì)這行記錄進(jìn)行讀取、更新;當(dāng)事務(wù)2對(duì)該記錄進(jìn)行更新時(shí),事務(wù)1再次讀取該記錄,讀到的仍然是第一次讀取的那個(gè)版本。
- 事務(wù)1更新某行記錄時(shí),事務(wù)2不能對(duì)這行記錄做更新,直到事務(wù)1結(jié)束。
4. SERIALIZABLE
- 事務(wù)在讀取數(shù)據(jù)時(shí),必須先對(duì)其加 表級(jí)共享鎖 ,直到事務(wù)結(jié)束才釋放;
- 事務(wù)在更新數(shù)據(jù)時(shí),必須先對(duì)其加 表級(jí)排他鎖 ,直到事務(wù)結(jié)束才釋放。
表現(xiàn):
- 事務(wù)1正在讀取A表中的記錄時(shí),則事務(wù)2也能讀取A表,但不能對(duì)A表做更新、新增、刪除,直到事務(wù)1結(jié)束。
- 事務(wù)1正在更新A表中的記錄時(shí),則事務(wù)2不能讀取A表的任意記錄,更不可能對(duì)A表做更新、新增、刪除,直到事務(wù)1結(jié)束。
數(shù)據(jù)庫(kù)鎖機(jī)制:悲觀鎖,樂(lè)觀鎖

image




