SQL Server 鎖機制

来源:https://www.cnblogs.com/leohahah/archive/2018/02/24/8465062.html
-Advertisement-
Play Games

鎖相容性圖: 一、鎖的粒度: 比較需要註意的是RID/KEY、HoBT/PAGE這兩對兒的區別,RID和HoBT是針對堆表的,即沒有聚集索引的表。 二、鎖的模式: 1.關於其中的S、U、X鎖: 共用鎖 共用鎖(S 鎖)允許併發事務在封閉式併發控制下讀取 (SELECT) 資源。 資源上存在共用鎖(S ...


鎖相容性圖:

一、鎖的粒度:

比較需要註意的是RID/KEY、HoBT/PAGE這兩對兒的區別,RID和HoBT是針對堆表的,即沒有聚集索引的表。

二、鎖的模式:

1.關於其中的S、U、X鎖:

共用鎖

共用鎖(S 鎖)允許併發事務在封閉式併發控制下讀取 (SELECT) 資源。 資源上存在共用鎖(S 鎖)時,任何其他事務都不能修改數據。 讀取操作一完成,就立即釋放資源上的共用鎖(S 鎖),除非將事務隔離級別設置為可重覆讀或更高級別,或者在事務持續時間內用鎖定提示保留共用鎖(S 鎖)。

更新鎖

更新鎖(U 鎖)可以防止常見的死鎖。 在可重覆讀或可序列化事務中,此事務讀取數據 [獲取資源(頁或行)的共用鎖(S 鎖)],然後修改數據 [此操作要求鎖轉換為排他鎖(X 鎖)]。 如果兩個事務獲得了資源上的共用模式鎖,然後試圖同時更新數據,則一個事務嘗試將鎖轉換為排他鎖(X 鎖)。 共用模式到排他鎖的轉換必須等待一段時間,因為一個事務的排他鎖與其他事務的共用模式鎖不相容;發生鎖等待。 第二個事務試圖獲取排他鎖(X 鎖)以進行更新。 由於兩個事務都要轉換為排他鎖(X 鎖),並且每個事務都等待另一個事務釋放共用模式鎖,因此發生死鎖。

若要避免這種潛在的死鎖問題,請使用更新鎖(U 鎖)。 一次只有一個事務可以獲得資源的更新鎖(U 鎖)。 如果事務修改資源,則更新鎖(U 鎖)轉換為排他鎖(X 鎖)。

排他鎖

排他鎖(X 鎖)可以防止併發事務對資源進行訪問。 使用排他鎖(X 鎖)時,任何其他事務都無法修改數據;僅在使用 NOLOCK 提示或未提交讀隔離級別時才會進行讀取操作。

數據修改語句(如 INSERT、UPDATE 和 DELETE)合併了修改和讀取操作。 語句在執行所需的修改操作之前首先執行讀取操作以獲取數據。 因此,數據修改語句通常請求共用鎖和排他鎖。 例如,UPDATE 語句可能根據與一個表的聯接修改另一個表中的行。 在此情況下,除了請求更新行上的排他鎖之外,UPDATE 語句還將請求在聯接表中讀取的行上的共用鎖。

2.關於其中的意向鎖: 意向鎖有兩種用途:
  • 防止其他事務以會使較低級別的鎖無效的方式修改較高級別資源。
  • 提高資料庫引擎在較高的粒度級別檢測鎖衝突的效率。

3.關於其中的架構鎖:

資料庫引擎在表數據定義語言 (DDL) 操作(例如添加列或刪除表)的過程中使用架構修改 (Sch-M) 鎖。 保持該鎖期間,Sch-M 鎖將阻止對錶進行併發訪問。 這意味著 Sch-M 鎖在釋放前將阻止所有外圍操作。

某些數據操作語言 (DML) 操作(例如表截斷)使用 Sch-M 鎖阻止併發操作訪問受影響的表。

資料庫引擎在編譯和執行查詢時使用架構穩定性 (Sch-S) 鎖。 Sch-S 鎖不會阻止某些事務鎖,其中包括排他 (X) 鎖。 因此,在編譯查詢的過程中,其他事務(包括那些針對錶使用 X 鎖的事務)將繼續運行。 但是,無法針對錶執行獲取 Sch-M 鎖的併發 DDL 操作和併發 DML 操作。

4.關於其中的大容量更新鎖: 大容量更新鎖(BU 鎖)允許多個線程將數據併發地大容量載入到同一表,同時防止其他不進行大容量載入數據的進程訪問該表。 在滿足以下兩個條件時,資料庫引擎使用大容量更新 (BU) 鎖。
  • 使用 Transact-SQL BULK INSERT 語句或 OPENROWSET(BULK) 函數,或者您使用某個大容量插入 API 命令(如 .NET SqlBulkCopy)、OLEDB 快速載入 API 或 ODBC 大容量複製 API 來將數據大容量複製到表。
  • TABLOCK指定提示或表大容量載入上的鎖表選項設置使用sp_tableoption。
5.關於其中的鍵範圍鎖: 在使用可序列化事務隔離級別時,對於 Transact-SQL 語句讀取的記錄集,鍵範圍鎖可以隱式保護該記錄集中包含的行範圍。 鍵範圍鎖可防止虛擬讀取。 通過保護行之間鍵的範圍,它還防止對事務訪問的記錄集進行虛擬插入或刪除。

關於鍵範圍鎖可以參考官網,或者另一篇博客SQL Server事務隔離級別中對於可序列化讀隔離級別的加鎖說明。

 

三、鎖升級

SQL Server資料庫會發生鎖升級,官網說明的鎖升級觸發條件為,如果沒有使用 ALTER TABLE SET LOCK_ESCALATION 選項來禁用表的鎖升級並且滿足以下任一條件時,觸發鎖升級:
  • 單個 Transact-SQL 語句在單個無分區表或索引上獲得至少 5,000 個鎖。
  • 單個 Transact-SQL 語句在已分區表的單個分區上獲得至少 5,000 個鎖,並且 ALTER TABLE SET LOCK_ESCALATION 選項設為 AUTO。
  • 資料庫引擎實例中的鎖的數量超出了記憶體或配置閾值。
  • 如果由於鎖衝突導致無法升級鎖,則資料庫引擎每當獲取 1,250 個新鎖時便會觸發鎖升級。
對於鎖升級的優化官網提供如下建議:
  1. 使用READ_COMMITTED_SNAPSHOT事務隔離級別。
  2. 使用SNAPSHOT事務隔離級別。
  3. 使用READ UNCOMMITTED事務隔離級別。
一般情況下我們只需要把READ_COMMITTED_SNAPSHOT選項打開即可,可以避免select加鎖,從而避免阻塞和鎖升級。 此外還可以打開1211和1224來避免鎖升級,但是極度不推薦,鎖升級本身就是為加快鎖獲取的效率而設計的,根本解決辦法還是優化SQL。   參考文檔 SQL Server 事務鎖定和行版本控制指南:https://msdn.microsoft.com/zh-cn/library/jj856598(v=sql.120).aspx 關於鎖升級,參考官方頁面:https://technet.microsoft.com/zh-cn/library/ms184286(v=sql.105).aspx
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 建表 2. 刪表 3. 常見數據類型 4. 聲明主碼 5. 聲明外碼 6. 聲明主碼,外碼的另一種方式 ...
  • 前言 對於生產環境,高可用是避免不了要面對的問題,無論什麼環境、服務,只要用於生產,就需要滿足高可用;此文針對的是redis的高可用。 接下來會有系列文章,該系列是對spring-session實現分散式集群session的共用的完整闡述,同時也引伸出緩存的實現;而此篇是該系列的第一篇。 githu ...
  • 帶emoji表情彈出層的評論框,semantic+emoji picker,java.sql.SQLException: Incorrect string value: '\xF0\x9F..' ...
  • ROW_NUMBER()函數將針對SELECT語句返回的每一行,從1開始編號,賦予其連續的編號 必須和over一起使用 select *,ROW_NUMBER() over(order by productid) as num from product_test; ...
  • 1增加主機映射(與namenode的映射一樣): 增加最後一行 2新建用戶hadoop 建立hadoop用戶組 新建用戶,useradd -d /usr/hadoop -g hadoop -m hadoop (新建用戶hadoop指定用戶主目錄/usr/hadoop 及所屬組hadoop) pass ...
  • 單個 節點 可以作為一個運行中的 Elasticsearch 的實例。 而一個 集群 是一組擁有相同 cluster.name 的節點, 他們能一起工作並共用數據,還提供容錯與可伸縮性。(當然,一個單獨的節點也可以組成一個集群) 你可以在 elasticsearch.yml 配置文件中 修改 clu... ...
  • ceiling函數返回大於或等於所給數字表達式的最小整數。 floor函數返回小於或等於所給數字表達式的最大整數。 eg: select ceiling(4.42) 5select CEILING(0.1) 1 select FLOOR(0.1)--0select FLOOR(4.42) 4 註意: ...
  • 索引 其實資料庫中的數據是按頁存放的其實索引也是按頁存放的所以本質上索引也占硬碟空間(以最小的消耗,換取最大的利益) 索引是一種有效組合數據的方式!為快速查找到指定記錄做鋪墊 目的就是快速或者某個記錄! 提高了資料庫的檢索速度!作用:大大提高資料庫的檢索速度改善資料庫性能 MySQL索引存儲類型分類 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...