事務併發之隔離級別

来源:http://www.cnblogs.com/mahl/archive/2016/12/12/6166451.html
-Advertisement-
Play Games

事務 事務是作為單個邏輯工作單元執行的一系列操作。一個邏輯工作單元必須有四個屬性,稱為原子性、一致性、隔離性和持久性 (ACID) 屬性,只有這樣才能成為一個事務。 事務併發 資料庫是多個用戶(事務)共用的,當多個用戶同時訪問數據時,那麼在這種情況下就叫做併發。 事務併發下可能出現的問題 更新丟失 ...


事務

事務是作為單個邏輯工作單元執行的一系列操作。一個邏輯工作單元必須有四個屬性,稱為原子性、一致性、隔離性和持久性 (ACID) 屬性,只有這樣才能成為一個事務。

事務併發

資料庫是多個用戶(事務)共用的,當多個用戶同時訪問數據時,那麼在這種情況下就叫做併發。

事務併發下可能出現的問題

更新丟失

兩個事務都同時更新一行數據,一個事務對數據的更新把另一個事務對數據的更新覆蓋了。這是因為系統沒有執行任何的鎖操作,因此併發事務並沒有被隔離開來。

臟讀

一個事務讀取到了另一個事務未提交的數據操作結果。這是相當危險的,因為很可能所有的操作都被回滾。

不可重覆讀

一個事務對同一行數據重覆讀取兩次,但是卻得到了不同的結果。

幻讀

幻讀發生在當兩個完全相同的查詢執行時,第二次查詢所返回的結果集跟第一個查詢不相同。

事務的隔離級別

讀未提交

當前事務可以讀取另一個事務未提交的記錄,非常危險,因為另一個事務可能完全回滾!

讀已提交

保證一個事務修改的數據提交後才能被另外一個事務讀取。

可重覆讀

這種事務隔離級別可以防止臟讀,不可重覆讀。但是可能出現幻讀!

序列化

事務被處理為順序執行。除了防止臟讀,不可重覆讀外,還避免了幻像讀。

LBCC-隔離級別

讀未提交

不加任何鎖

 

讀已提交

讀數據加共用鎖 
更改數據加排他鎖 
共用鎖讀完立即釋放

 

可重覆讀

讀數據加共用鎖 
更改數據加排他鎖 
共用鎖事務結束才釋放

 

序列化

讀數據加共用鎖 
更改數據加排他鎖 
共用鎖事務結束才釋放 
增加範圍鎖

 

 

 

 什麼鬼?可重覆讀和讀已提交兩種隔離級別得出的結論跟LBCC協議不一致!!!懷疑人生中……

 

MVCC協議

MVCC–多版本併發控制協議

通過保存數據在某個時間點的快照來實現,也就是說,不管需要執行多長時間,每個事務看到的數據都是一致的。不同的存儲引擎MVCC的實現是不同的,典型的有樂觀併發控制和悲觀併發控制。

 

MVCC實現原理(Innodb引擎)

 Innodb引擎會為每一行添加兩個隱藏的列來實現的,分別表示該行創建版本和刪除版本,創建版本是事務的版本號,每開始一個新的事務,版本號會自動遞增。

舉個慄子,偷幾張圖...

初始化數據

 

事務1

事務2

 

讀已提交

讀事務每次都讀取undo log中最近的版本,因此兩次對同一欄位的讀可能讀到不同的數據(幻讀),但能保證每次都讀到最新的數據

可重覆讀

 每次都讀取指定的版本,這樣保證不會產生幻讀,但可能讀不到最新的數據

 

總結

  1. 對於許多SQL,隔離級別越高,InnoDB給記錄集加的鎖就越嚴格,產生鎖衝突的可能性就越高,從而對併發事務處理性的影響也就越大。

  2. 因此我們在項目中,應該儘量使用較低的隔離級別,以減少鎖爭用的幾率。

  3. InnoDB引擎儘量使用索引,防止鎖表。
  4. 合理使用事務的大小,小事務發生鎖衝突的幾率也更小。
  5. 儘量使用相等條件,避免Next-key鎖對併發插入的影響(gap鎖)

參考

  1. 高性能Mysql
  2. 深入淺出Mysql

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

-Advertisement-
Play Games
更多相關文章
  • 今天我們一起來探討下安卓中BroadcastReceiver組件以及詳細分析下它的兩種註冊方式。 BroadcastReceiver也就是“廣播接收者”的意思,顧名思義,它就是用來接收來自系統和應用中的廣播。在Android系統中,廣播體現在方方面面,例如當開機完成後系統會產生一條廣播,接收到這條廣 ...
  • 今日,在學習AnimatorSet時,使用play、with、after、before時,代碼書寫如下: 運行代碼時,報錯,錯誤報告如下: 然後,我將set.play(animator1).after(animator2).before(animator3).with(animator2);代碼修改 ...
  • Toast的多種使用方法 Toast其實是一個功能特別強大的組件,不僅僅可以吐司一個文本內容,還可以吐司圖片以及圖文混排的界面。具體用法如下: 第一種:簡單的純文本內容的吐司: 第二種:吐司一張圖片: 第三種:圖文混合吐司 Toast還有一些其它的屬性,知道這最基本的,然後發揮我們的想象,t就可以利 ...
  •   對於直播來說,客戶端主要做兩件事情,推流和播放。今天先講播放。 播放流程 1.拉流:伺服器已有直播內容,從指定地址進行拉取的過程。其實就是向伺服器請求數據。 2.解碼:對視屏數據進行解壓縮。 3.渲染:生成圖片的過程。視屏其實就是一張張連續的圖片進行切換,一張圖片就是一幀。幀 ...
  • ➠更多技術乾貨請戳:聽雲博客 動態鏈接 要解決空間浪費和更新困難這兩個問題最簡單的方法就是把程式的模塊相互分割開來,形成獨立的文件,而不再將它們靜態的鏈接在一起。簡單地講,就是不對那些組成程式的目標文件進行鏈接,等到程式要運行時才進行鏈接。也就是說,把鏈接過程推遲到了運行時再進行,這就是 _動態鏈接 ...
  • 示例一:實現通知欄管理 當針對相同類型的事件多次發出通知,作為開發者,應該避免使用全新的通知,這時就應該考慮更新之前通知欄的一些值來達到提醒用戶的目的。例如我們手機的簡訊系統,當不斷有新消息傳來時,我們的通知欄僅僅是更改傳來簡訊的數目,而不是對每條簡訊單獨做一個通知欄用於提示。 修改通知 可以設置一 ...
  • 今天在寫微信登錄,花了半天時間搞定、然後寫下自己的筆記,希望幫助更多的人。。。歡迎各位指教。 微信授權登錄,官方說的不是很清楚、所以導致有一部分的坑。 微信註冊應用平臺的應用簽名,下載 微信簽名生成工具 輸入項目的packageName也可以查看到。 (註意:debug、Release 一定要區分, ...
  • 在SQL Server中導入數據時,會有一個“啟用標示插入”的選項,突然間懵逼了,這到底啥意思?我選與不選這個選項,結果好像沒區別!不科學啊這,“存在即合理”,我相信這個選項肯定有它的用處,只是我不知道罷了。 於是我去查資料,在CSDN論壇里找到了可能的解釋: 1)首先:“啟用標示插入”只對標示列( ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...