1. 程式人生 > >mysql 事務隔離級別詳解

mysql 事務隔離級別詳解

bat con enc ron 問題 修改方法 復讀 get 很多

事物的 隔離級別,說簡單非常簡單(新手也能說出 是個隔離級別 和 影響),說男也非常難。(很多 有幾年編程 經驗的程序員依舊搞不清楚)

廢話不多少 直接開始:

事務的隔離級別 是用來描述 事務的讀關系的,和寫完全沒有關系。所有數據庫都不允許修改一個事務未提交的數據行。

Read Uncommitted(讀取未提交內容)

  描述的是。一個未提交的事務裏面修改的數據,可以立即被另一個事務查詢到( 臟讀(Dirty Read) )

  實驗設計1: 吧數據庫隔離級別改成Read Uncommitted , 兩個方法 一個循環 查詢 出指定 行,每查一次睡一秒。另一個方法 修改這 一行的數據,但是不提交事務(睡 100 秒) 。 先調用查詢方法,然後調用修改方法,

  結果:修改立即被查詢方法查詢到。我們讀到了臟數據。

Read Committed(讀取提交內容)

    描述:只能讀到已經提交的事務修改的數據,但是在 同一個事務的 2次查詢中 ,可以讀取到 另一個事務提交了的數據。

   實驗式設計2: 吧數據庫隔離級別改成Read Committed ,兩個方法 一個循環 查詢 出指定 行,每查一次睡一秒。另一個方法 修改這 一行的數據,並且提交事務 。 先調用查詢方法,然後調用修改方法,

   結果: 用 實驗1 驗證 不能讀到臟數據,用實驗2 驗證 2 修改可以被 感知。

  備註:實驗2 可能會被緩存影響。如果沒有發出多次查詢sql ,那麽就是緩存的影響了,需要關閉mybatis 的 緩存。

    springboot 關閉mybits 緩存的方法如下:

      

mybatis:
  configuration:
    cache-enabled: false
    local-cache-scope: STATEMENT

  

     

Repeatable Read(可重讀)

  

 描述:Repeatable Read 是mysql 的 默認級別 。 一般的解釋 它 可以 避免 不可重復讀,但是不能 避免幻讀,但是 mysql InnoDB和Falcon存儲引擎通過多版本並發控制(MVCC,Multiversion Concurrency Control)機制解決了該問題

  也就是說 mysql 的這個級別已經不會出 幻讀 了。關於幻讀的解釋:幻讀 (Phantom Read)。簡單的說,幻讀指當用戶讀取某一範圍的數據行時,另一個事務又在該範圍內插入了新行,當用戶再讀取該範圍的數據行時,會發現有新的“幻影” 行。

  實驗3:修改實驗2 ,查詢 改成查詢一共有多少行,修改 方法改成查詢方法;

  結果: 利用實驗2證明不在出現 不可重復讀,利用 實驗3 證明 InnoDB 解決了幻讀。

  備註: InnoDB mysql 默認的 數據庫引擎

Serializable(可串行化) 不管讀事務還是寫事務都加了獨占鎖。只能一個事務結束以後,贏一個事務才能執行。

  這個最好認證,查詢事務沒有提交的時候寫事務是不能執行的。

怎麽修改 mysql的 事務 隔離級別 和 查詢 mysql的 隔離級別 在我的另一篇文章中:https://www.cnblogs.com/cxygg/p/9338555.html

mysql 事務隔離級別詳解