1. 程式人生 > >資料庫事務隔離級別,髒讀、不可重複讀、幻讀

資料庫事務隔離級別,髒讀、不可重複讀、幻讀

資料庫事務的隔離級別有4個,由低到高依次為Read uncommitted 、Read committed 、Repeatable read 、Serializable  ,後面三個可以逐個解決髒讀 、不可重複讀 、幻讀 這幾類問題。
髒讀 不可重複讀 幻讀
Read uncommitted
Read committed ×
Repeatable read × ×
Serializable × × ×

Read uncommitted 讀未提交
事務B讀取了事務A尚未提交的資料,就會造成髒讀。 當隔離級別設定為Read uncommitted 時,就可能出現髒讀,如何避免髒讀,請看下一個隔離級別。
Read committed 讀提交
當隔離級別設定為Read committed 時,避免了髒讀,但是可能會造成不可重複讀。 大多數資料庫的預設級別就是Read committed,比如Sql Server , Oracle。如何解決不可重複讀這一問題,請看下一個隔離級別。
Repeatable read 重複讀
當隔離級別設定為Repeatable read 時,可以避免不可重複讀。 雖然Repeatable read避免了不可重複讀,但還有可能出現幻讀 。 注:Mysql的預設隔離級別就是Repeatable read。
Serializable 序列化
Serializable 是最高的事務隔離級別,同時代價也花費最高,效能很低,一般很少使用,在該級別下,事務順序執行,不僅可以避免髒讀、不可重複讀,還避免了幻像讀。 二、
髒讀、幻讀、不可重複讀 1.髒讀: 髒讀就是指當一個事務正在訪問資料,並且對資料進行了修改,而這種修改還沒有提交到資料庫中,這時,另外一個事務也訪問這個資料,然後使用了這個資料。 2.不可重複讀: 是指在一個事務內,多次讀同一資料。在這個事務還沒有結束時,另外一個事務也訪問該同一資料。那麼,在第一個事務中的兩次讀資料之間,由於第二個事務的修改,那麼第一個事務兩次讀到的的資料可能是不一樣的。這樣就發生了在一個事務內兩次讀到的資料是不一樣的,因此稱為是不可重複讀。(即不能讀到相同的資料內容) 例如,一個編輯人員兩次讀取同一文件,但在兩次讀取之間,作者重寫了該文件。當編輯人員第二次讀取文件時,文件已更改。原始讀取不可重複。如果只有在作者全部完成編寫後編輯人員才可以讀取文件,則可以避免該問題。 3.幻讀:
是指當事務不是獨立執行時發生的一種現象,例如第一個事務對一個表中的資料進行了修改,這種修改涉及到表中的全部資料行。同時,第二個事務也修改這個表中的資料,這種修改是向表中插入一行新資料。那麼,以後就會發生操作第一個事務的使用者發現表中還有沒有修改的資料行,就好象 發生了幻覺一樣。 例如,一個編輯人員更改作者提交的文件,但當生產部門將其更改內容合併到該文件的主複本時,發現作者已將未編輯的新材料新增到該文件中。如果在編輯人員和生產部門完成對原始文件的處理之前,任何人都不能將新材料新增到文件中,則可以避免該問題。 注:幻讀的重點在於新增或者刪除,不可重複讀的重點是修改