數據庫中隔離級別的操作
- 設置隔離級別:set tx_isolation = 'READ-UNCOMMITTED'
- 查看隔離級別:select @@tx_isolation
一、Read Uncommitted -- 讀取未提交內容
- 一個事務可以查看到未提交的內容
- 常產生臟讀問題(臟讀:讀取到其他事務未提交(執行)的內容)
對同一數據表開啟A、B兩個事務(A、B事務交叉) start transaction
A事務只查詢數據表中內容,B事務做增刪改操作但不commit(提交)
A事務依舊可以查詢到表中的數據改變(查詢到未提交的內容--臟讀)
二、Read Committed -- 讀取提交內容
- 一個事務只能查看已提交的內容
- 常產生不可重復讀的問題(不可重復讀:同一事務中執行相同的select語句得到不同的結果)
對同一數據表開啟A、B兩個事務(A、B事務交叉) start transaction
A事務只查詢數據表中內容,B事務做增刪改操作但不commit(提交)
A事務查詢不到表中的數據改變的內容
B事務提交
A查到的數據改變(A兩次查詢,產生不同的結果--不可重復讀)
三、Repeatable Read -- 可重讀
- 同一事務的多個實例並發讀取數據時得到同一結果
- MySQL的默認事務隔離級別
- 常產生幻讀問題(幻讀:多次讀取時產生不同結果(幻影行))
對同一數據表開啟A、B兩個事務(A、B事務交叉) start transaction
A事務只查詢數據表中內容,B事務做增刪改操作但不commit(提交)
A事務查詢不到表中的數據改變的內容
B事務提交
A事務查詢不到表中的數據改變的內容
A提交
A可查詢到表中數據的改變
四、Serializable -- 可串行化
- 最高隔離級別
- 給事務加上共享鎖,同時只能有一個事務操作,解決幻讀問題
- 會導致大量超時和鎖競爭問題
開啟A事務
開啟B事務時無法增刪該操作