事務的四個隔離級別


數據庫中隔離級別的操作

  • 設置隔離級別: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事務時無法增刪該操作


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM