事務的四個隔離級別分別是什么

事務的四個隔離級別分別是:1、讀取未提交內容(Read Uncommitted);2、讀取提交內容(Read Committed);3、可重讀(Repeatable Read);4、可串行化(Serializable)。

事務的四個隔離級別分別是什么

事務的四個隔離級別:

(推薦學習:mysql教程

一、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事務時無法增刪該操作

? 版權聲明
THE END
喜歡就支持一下吧
點贊13 分享