Mysql InnoDB的四個事務隔離級別和(分別逐級解決的問題)臟讀,不可重覆讀,虛讀

来源:http://www.cnblogs.com/qjm575632320/archive/2017/09/15/7527012.html
-Advertisement-
Play Games

MySqlInnoDB的事務隔離級別有四個:(預設是可重覆讀repeatable read) 未提交讀 read uncommit : 在另一個事務修改了數據,但尚未提交,在本事務中SELECT語句可能會查詢到這些未被提交的數據,而發生臟讀。 提交讀 read commit : 在一個事務中發生兩次 ...


MySqlInnoDB的事務隔離級別有四個:(預設是可重覆讀repeatable read)

未提交讀 read uncommit : 在另一個事務修改了數據,但尚未提交,在本事務中SELECT語句可能會查詢到這些未被提交的數據,而發生臟讀。

提交讀 read commit : 在一個事務中發生兩次SELECT查詢,當第一次SELECT執行完查詢到一些數據,接下來另一個事務修改了這些數據並提交了,當第二次SELECT執行的時候查詢到的數據和第一次SELECT的不同,而發生不可重覆讀、幻讀問題,但解決了臟讀(鎖定所讀取的當前行)。

可重覆讀 repeatable read:在同一個事務中,SELECT的結果是事務開啟時時間點的結果,因此,同樣的SELECT查詢的結果總是一致的。解決了不可重覆讀,但有可能發生虛讀(鎖定所讀取的所有行)。

串列化 serializable:

(轉載的)

    1). 臟讀 

      首先區分臟頁和臟數據

      臟頁是記憶體的緩衝池中已經修改的page,未及時flush到硬碟,但已經寫到redo log中。讀取和修改緩衝池的page很正常,可以提高效率,flush即可同步。臟數據是指事務對緩衝池中的行記錄record進行了修改,但是還沒提交!!!,如果這時讀取緩衝池中未提交的行數據就叫臟讀,違反了事務的隔離性。臟讀就是指當一個事務正在訪問數據,並且對數據進行了修改,而這種修改還沒有提交到資料庫中,這時,另外一個事務也訪問這個數據,然後使用了這個數據。

    2). 不可重覆讀 

     是指在一個事務內,多次讀同一數據。在這個事務還沒有結束時,另外一個事務也訪問該同一數據。那麼,在第一個事務中的兩次讀數據之間,由於第二個事務的修改,第二個事務已經提交。那麼第一個事務兩次讀到的的數據可能是不一樣的。這樣就發生了在一個事務內兩次讀到的數據是不一樣的,因此稱為是不可重覆讀。例如,一個編輯人員兩次讀取同一文檔,但在兩次讀取之間,作者重寫了該文檔。當編輯人員第二次讀取文檔時,文檔已更改。原始讀取不可重覆。如果只有在作者全部完成編寫後編輯人員才可以讀取文檔,則可以避免該問題

    3). 虛讀 :

     是指當事務不是獨立執行時發生的一種現象,例如第一個事務對一個表中的數據進行了修改,這種修改涉及到表中的全部數據行。同時,第二個事務也修改這個表中的數據,這種修改是向表中插入一行新數據。那麼,以後就會發生操作第一個事務的用戶發現表中還有沒有修改的數據行,就好象發生了幻覺一樣。例如,一個編輯人員更改作者提交的文檔,但當生產部門將其更改內容合併到該文檔的主複本時,發現作者已將未編輯的新材料添加到該文檔中。如果在編輯人員和生產部門完成對原始文檔的處理之前,任何人都不能將新材料添加到文檔中,則可以避免該問題。

事務A connection.setAutoCommit(false) start Transaction  

update student set money=money+100

from account

where name='a'

  commit();   insert into account (name,money)values('fff',10000);    
(事務B) connection.setAutoCommit(false) start Transaction

select money from account where name='a';

發現有1000塊

 

 

 

select money from account where name='a';

發現有1100

 

select money from account where name='a';

發現有1100

  select * from account (查詢結果包含fff的信息) commit();
說明         事務B讀到了事務A未提交的數據,發生了臟讀   事務A提交後,事務B前後SELECT查詢money的值不一致,即事務B讀到了事務A,update後的數據,發生了不可重覆讀   虛讀(即一個事務讀到了另一個事務insert的數據)  
可設置的事務級別         read commit   repeatable read   串列化serializable  

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近在優化項目雖說小優化一直在持續,大版本的優化也進行了兩個版本了但是bug列表依舊血淋淋的擺在那裡。有的看一眼也能找到問題所在但是有的就是想破頭也不知道問題在哪裡,畢竟整個項目經過了N個人的手代碼風格迥異閱讀起來也會有不小的困難,因此在這分享一下解決這些個bug之間遇到的問題和一些看似實用的方法。 ...
  • UIScrollView,UICollectionView 和UITableView 三者之間的關係:UIScrollView是 UICollectionView 和 UITableView 的父類. UIScrollView 一個可以滾動的視圖控制項,可以用來查看比屏幕大很多的視圖內容. 常用屬性: ...
  • OC開發中一般都會使用model來處理數據,經常會碰到定義好的欄位因為各種原因 後臺突然改欄位或者空值 造成model中對應的數值為nil,這個時候 我們如果取這個值加入數組中使用就會發現數組中的參數個數少了,造成閃退。因為在OC中數組無需要預先申請空間 數組每增加或刪除一個元素,就增加或刪除一個節 ...
  • 首先手機連接電腦,打開 ITunes. 左上角點擊文件,再點擊添加到資料庫。 找到你要安裝的ipa點擊選擇打開 好了ipa已經添加進去後,你會看你你剛纔添加進去的應用在列表內,點擊左上角一個手機的圖標。 點擊安裝,右下角同步 便成功安裝到手機上了。 此隨筆乃本人學習工作記錄,如有疑問歡迎在下麵評論, ...
  • 移動的號段:134(0-8)、135、136、137、138、139、147(預計用於TD上網卡) * 、150、151、152、157(TD專用)、158、159、187(未啟用)、188(TD專用) 聯通的號段:130、131、132、155、156(世界風專用)、185(未啟用)、186(3g ...
  • 作為一個一直使用windows系統的人,還真不知道mac上的svn如何使用,偶然機會下現在需要。 查過後發現 mac 是自帶svn的,在我裝好xcode後,再安裝 Command Line Tools 1.打開終端 輸入 點擊安裝,過幾分鐘就安好了。 2.再輸入此命令查看版本號,有版本號就是安裝好了 ...
  • mysql -h 192.168.1.104 -P3306 -uroot -p 然後輸入你安裝時設置的MySQL密碼 發現Can't connect to MySQL server 你的IP 解決方法: (1)用localhost 登錄 mysql -h localhost -P3306 -uroo ...
  • 一 快速性 如果在記憶體中運行MapRaduce,要比Hadoop快100倍 如果在磁碟中運行,要比Hadoop快10倍 Spark使用先進的有向無環圖執行引擎來支持非迴圈的數據流在記憶體中計算 二 易用性 Spark提供超過80個高階運算元,這些運算元使其很容易構建並行應用 這些運算元支持多種語言 按照切合 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...