InnoDB 中不同SQL語句設置的鎖

来源:https://www.cnblogs.com/cjsblog/archive/2022/08/03/16544690.html
-Advertisement-
Play Games

鎖定讀、UPDATE 或 DELETE 通常會給在SQL語句處理過程掃描到的每個索引記錄上設置記錄鎖。語句中是否存在排除該行的WHERE條件並不重要。InnoDB不記得確切的WHERE條件,但只知道哪些索引範圍被掃描了。鎖通常是next-key鎖,它也阻止插入到緊挨著記錄之前的“間隙”中。然而,間隙 ...


鎖定讀、UPDATE 或 DELETE 通常會給在SQL語句處理過程掃描到的每個索引記錄上設置記錄鎖。語句中是否存在排除該行的WHERE條件並不重要。InnoDB不記得確切的WHERE條件,但只知道哪些索引範圍被掃描了。鎖通常是next-key鎖,它也阻止插入到緊挨著記錄之前的“間隙”中。然而,間隙鎖定可以顯式禁用,這會導致next-key鎖無法使用。事務隔離級別也會影響到鎖的設置。

如果在搜索中使用了二級索引,並且要設置的索引記錄鎖是互斥的,InnoDB也會檢索相應的聚集索引記錄並對它們設置鎖。

如果沒有適合語句的索引,MySQL必須掃描整個表來處理該語句,那麼表的每一行都將被鎖定,從而阻止其他用戶對錶的所有插入。創建良好的索引非常重要,這樣查詢就不會掃描不必要的行。

InnoDB設置的鎖的具體類型如下:

1、SELECT ... FROM 是一個一致讀,讀取資料庫的快照並且不設置鎖,除非將事務隔離級別設置為SERIALIZABLE。

2、唯一索引的 SELECT ... FOR UPDATE 和 SELECT ... FOR SHARE 語句為掃描的行獲取鎖,並釋放不符合包含在結果集中條件的行(例如,如果它們不滿足WHERE子句中給定的條件)的鎖。然而,在某些情況下,行可能不會立即被解鎖,因為在查詢執行期間,結果行與其原始源之間的關係丟失了。例如,在UNION中,從表中掃描(和鎖定)的行可能會在評估它們是否符合結果集之前插入臨時表。在這種情況下,臨時表中的行與原始表中的行之間的關係將丟失,而後者的行直到查詢執行結束才被解鎖。

3、對於鎖定讀(帶有 FOR UPDATE 或 FOR SHARE 的 SELECT)、UPDATE 和 DELETE 語句,所採用的鎖取決於語句是使用具有唯一搜索條件的唯一索引,還是使用範圍類型的搜索條件。

  • 對於具有唯一搜索條件的唯一索引,InnoDB 只鎖定找到的索引記錄,而不鎖定它之前的間隙。
  • 對於其他搜索條件和非唯一索引,InnoDB鎖定所掃描的索引範圍,使用間隙鎖或next-key鎖阻止其他會話對該範圍覆蓋的間隙進行插入。

4、對於搜索遇到的索引記錄,SELECT ... FOR UPDATE 阻止其他會話執行 SELECT ... FOR SHARE 或從某些事務隔離級別讀取。一致讀忽略在讀視圖中存在的記錄上設置的任何鎖。

5、UPDATE ... WHERE ... 在搜索遇到的每條記錄上設置一個排它的next-key鎖。但是,對於使用唯一索引來搜索唯一行的語句,只需要一個索引記錄鎖。

6、DELETE FROM ... WHERE ... 在搜索遇到的每條記錄上設置一個排它的next-key鎖。但是,對於使用唯一索引來搜索唯一行的語句,只需要一個索引記錄鎖。

7、當 UPDATE 修改聚集索引記錄時,將對受影響的二級索引記錄進行隱式鎖定。在插入新的二級索引記錄之前執行重覆檢查掃描,以及在插入新的二級索引記錄時,UPDATE操作還會在受影響的二級索引記錄上使用共用鎖。

8、INSERT 在插入的行上設置排它鎖。這個鎖是索引記錄鎖,不是next-key鎖(即沒有間隙鎖),並且不會阻止其他會話插入到插入行之前的間隙中。

9、在插入行之前,設置了一種稱為插入意向間隙鎖的間隙鎖。該鎖表示要以這樣一種方式插入,即插入到同一索引間隙的多個事務如果不在間隙內的同一位置插入,則不需要相互等待。假設有值為4和7的索引記錄。嘗試插入值5和6的獨立事務在獲得插入行上的排它鎖之前,每個事務都用插入意向鎖鎖定4和7之間的間隙,但不會阻塞彼此,因為行是不衝突的。

10、INSERT ... ON DUPLICATE KEY UPDATE 與簡單的 INSERT 不同之處在於,當發生重覆鍵錯誤時,將在要更新的行上放置排他鎖而不是共用鎖。對重覆的主鍵值採用排它索引記錄鎖。對重覆的唯一鍵值採用排它的next-key鎖。

11、INSERT INTO T SELECT ... FROM S WHERE ... 在插入到 T 的每一行上設置一個排它索引記錄鎖(沒有間隙鎖)。如果事務隔離級別為 READ COMMITTED,InnoDB 將 S 上的搜索作為一致 讀(無鎖)。 否則,InnoDB 在 S 的行上設置共用的 next-key 鎖。

12、InnoDB在初始化表上先前指定的AUTO_INCREMENT列時,會在與AUTO_INCREMENT列相關的索引的末尾設置一個排它鎖。

13、如果在表上定義了一個FOREIGN KEY約束,那麼任何需要檢查約束條件的插入、更新或刪除都會在它查看的記錄上設置共用記錄級別的鎖,以檢查約束。InnoDB會在約束失敗的情況下也設置這些鎖。

14、LOCK TABLES設置表鎖,但是設置這些鎖的是InnoDB層之上的MySQL層。如果innodb_table_locks = 1(預設值)和autocommit = 0, InnoDB就知道表鎖,而且InnoDB上面的MySQL層知道行級鎖。

 

https://dev.mysql.com/doc/refman/8.0/en/innodb-locks-set.html

https://dev.mysql.com/doc/refman/8.0/en/innodb-transaction-isolation-levels.html

https://dev.mysql.com/doc/refman/8.0/en/innodb-locking.html

 

給表現加一個意向排它鎖,然後給行id=4的行加排它的記錄鎖,以及正無窮

 


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

-Advertisement-
Play Games
更多相關文章
  • 一:背景 1. 講故事 前段時間遇到了好幾起關於窗體程式的 進程載入鎖 引發的 程式卡死 和 線程暴漲 問題,這種 dump 分析難度較大,主要涉及到 Windows操作系統 和 C++ 的基礎知識,所以有必要簡單整理和大家分享一下,上 windbg 說話。 二:WinDbg 分析 1. 主線程此時 ...
  • 經過長時間的規劃和編碼,終於出來了.NET 版本的微服務框架,而且框架的使用簡單,無入侵集成,可幫助任意項目輕鬆向大併發架構演進。 ...
  • 前言 接著上周寫的截圖控制項繼續更新添加 文字。 1.WPF實現截屏「仿微信」 2.WPF 實現截屏控制項之移動(二)「仿微信」 3.WPF 截圖控制項之伸縮(三) 「仿微信」 4.WPF 截圖控制項之繪製方框與橢圓(四) 「仿微信」 5.WPF 截圖控制項之繪製箭頭(五)「仿微信」 6.WPF 截圖控制項之繪 ...
  • 為什麼要用ssh密鑰登錄 購買的伺服器設置密碼很容易被暴力破解,用密鑰登錄安全很多。root用戶新建的用戶也要用密鑰登錄更安全,如果一直su - 用戶名登錄 不方便 用xftp等服務上傳文件到用戶使用的服務下,歸屬人是root,還要chown改許可權才能使用。 為其他用戶創建ssh密鑰的步驟 # 密鑰 ...
  • Naarak Studio DirEqua mac版是Mac的高級目錄比較實用程式。它可以檢測文件夾之間最小的變化,並以清晰直觀的方式顯示結果。使用顏色和圖標突出顯示差異類型(大小,日期或項目內容),以突出顯示差異。DirEqual Mac版將比較的目錄併排顯示為可擴展樹,併為每個項目指示大小和日期 ...
  • sudo:superuser do,實現普通用戶執行root命令的授權工具。 一般用戶管理系統的方式是利用su切換為超級用戶。但是使用su的缺點之一在於必須要先告知超級用戶的密碼。 sudo使一般用戶不需要知道超級用戶的密碼即可獲得許可權 #過程: (1)超級用戶授權:首先 超級用戶 將普通用戶的名字 ...
  • 今天是接觸C++的第二天,學習了基礎內容之後用了兩個多小時的時間完成了一個通訊錄管理程式,功能相對簡單,代碼也不複雜,歡迎各位大佬指出不足之處 點擊查看代碼 #include<iostream> #include<string> #include<regex> using namespace std ...
  • lamp 1. lamp簡介 lamp,其實就是由Linux+Apache+Mysql/MariaDB+Php/Perl/Python的一組動態網站或者伺服器的開源軟體 LAMP指的是Linux(操作系統)、Apache(HTTP伺服器)、MySQL(也指MariaDB,資料庫軟體)和PHP(有時也 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...