1. 程式人生 > >SQL SERVER 事務鎖 (3)

SQL SERVER 事務鎖 (3)

資料庫的髒讀、不可重複讀、幻讀都和事務的隔離性有關。所以先了解一下事務的4大特性。
事務的4大特性(ACID):

原子性(Atomicity):事務是資料庫的邏輯工作單位,它對資料庫的修改要麼全部執行,要麼全部不執行。
一致性(Consistemcy):事務前後,資料庫的狀態都滿足所有的完整性約束。
隔離性(Isolation):併發執行的N個事務是隔離的,一個不影響一個,一個事務在沒有commit之前,被修改的資料不可能被其他事務看到(通過設定資料庫的隔離級別)。
永續性(Durability):永續性意味著當系統或介質發生故障時,確保已提交事務的更新不能丟失。永續性主要在於DBMS的恢復效能。

髒讀:

髒讀又稱無效資料讀出。一個事務讀取另外一個事務還沒有提交的資料叫髒讀。

例如:事務T1修改了一行資料,但是還沒有提交,這時候事務T2讀取了被事務T1修改後的資料,之後事務T1因為某種原因Rollback了,那麼事務T2讀取的資料就是髒的。

解決辦法:把資料庫的事務隔離級別調整到READ_COMMITTED

不可重複讀:

不可重複讀是指在同一個事務內,兩個相同的查詢返回了不同的結果。
例如:事務T1讀取某一資料,事務T2讀取並修改了該資料,T1為了對讀取值進行檢驗而再次讀取該資料,便得到了不同的結果。 解決辦法:把資料庫的事務隔離級別調整到REPEATABLE_READ

幻讀:

例如:系統管理員A將資料庫中所有學生的成績從具體分數改為ABCDE等級,但是系統管理員B就在這個時候插入了一條具體分數的記錄,當系統管理員A改結束後發現還有一條記錄沒有改過來,就好像發生了幻覺一樣。這就叫幻讀。

解決辦法:把資料庫的事務隔離級別調整到SERIALIZABLE_READ

髒讀、不可重複讀、幻讀的級別高低是:髒讀 < 不可重複讀 < 幻讀。所以,設定了最高級別的SERIALIZABLE_READ就不用在設定REPEATABLE_READ和READ_COMMITTED了

本文來自 JavaHSJ 的CSDN 部落格 ,全文地址請點選:https://blog.csdn.net/stu_hsj/article/details/46603681