MySQL 基礎知識梳理學習(六)----鎖

来源:https://www.cnblogs.com/xuliuzai/archive/2019/01/31/10339372.html
-Advertisement-
Play Games

1.什麼是鎖: 對共用資源進行併發訪問,提供數據的完整性和一致性。 2.鎖的區別: Lock Manager的哈希表中 latch是針對程式內部的資源(比如:全局變數)的鎖的定義,而這裡的lock針對的是資料庫的事務。 lock有latch來保證和實現。 3.鎖是用來實現併發控制,併發控制用來實現隔 ...


1.什麼是鎖:

對共用資源進行併發訪問,提供數據的完整性和一致性。

2.鎖的區別:

類型 lock latch
對象 事務 線程
保護 資料庫內容 記憶體數據結構
持續時間 整個事務過程 臨界資源
模式 行鎖、表鎖、意向鎖 讀寫鎖、互斥量
死鎖 通過waits-for graph、time out等機制進行死鎖檢測與處理 無死鎖檢測與處理機制。僅通過應用程式加鎖的順序(latch leveling)保證無死鎖的情況發生。
存在於

Lock Manager的哈希表中

每個數據結構對象中

latch是針對程式內部的資源(比如:全局變數)的鎖的定義,而這裡的lock針對的是資料庫的事務。

lock有latch來保證和實現。

3.鎖是用來實現併發控制,併發控制用來實現隔離級別,隔離級別是通過鎖來控制的,鎖的目的為了使得事務之間的執行是序列化的。

4. 什麼是隔離性

一個事務所做的修改,對其它事務時不可見的,好似是串列執行的。

隔離級別越低,事務請求的鎖越少或者保持鎖的時間就越短。

5.MySQL事務的隔離級別

事務隔離級別 臟讀 不可重覆讀 幻讀
讀未提交(read-uncommitted)
不可重覆讀(read-committed)
可重覆讀(repeatable-read)
串列化(serializable)

MySQL 預設的事務隔離級別為repeatable-read。

6.什麼是臟讀、不可重覆讀、幻讀

(1)臟讀:事務A讀取了事務B更新(插入)的數據,然後B回滾操作,那麼A讀取的數據是臟數據。即尚未提交(commit)的數據,被其他的事務讀取了。

(2)不可重覆讀:事務A多次讀取同一數據(同一條記錄),事務B在事務A多次讀取的過程中,對數據做了更新並提交,導致事務A多次讀取同一數據時,結果不一致。

(3)幻讀:在同一個事務中,執行兩次相同的SQL,等到不同的結果集,(新增了部分記錄或者缺失了部分記錄)(與不可重覆讀操作對象不一樣,此處,不是同一條記錄)。

小結:不可重覆讀和幻讀很容易混淆,不可重覆讀偏重於修改,幻讀側重於新增或刪除。解決不可重覆讀的問題只需鎖住滿足條件的行,解決幻讀需要鎖表。

7.MySQL InnoDB支持三種行鎖定方式

Record Lock 單個行記錄上的鎖;
Gap Lock 鎖定一個範圍,但不包含記錄本身;間隙鎖是針對事務隔離級別為可重覆讀或以上級別,解決了幻讀的問題。locking reads,UPDATE和DELETE時,除了對唯一索引的唯一搜索外都會獲取gap鎖或next-key鎖。即鎖住其掃描的範圍。
Next-Key Lock Gap Lock + Record Lock,鎖定一個範圍,並且鎖定記錄本身。

8.(1)事務隔離級別為讀提交時,寫數據只會鎖住相應的行。

 (2)事務隔離級別為可重覆讀時,如果檢索條件有索引(包括主鍵索引)的時候,預設加鎖方式是next-key 鎖;如果檢索條件沒有索引,更新數據時會鎖住整張表。一個間隙被事務加了鎖,其他事務是不能在這個間隙插入記錄的,這樣可以防止幻讀。

 (3)事務隔離級別為串列化時,讀寫數據都會鎖住整張表

 (4)隔離級別越高,越能保證數據的完整性和一致性,但是對併發性能的影響也越大。

9.間隙鎖鎖定的區域
根據檢索條件向左尋找最靠近檢索條件的記錄值A,作為左區間,向右尋找最靠近檢索條件的記錄值B作為右區間,即鎖定的間隙為(A,B)。

10.死鎖

死鎖是兩個或兩個以上的事務在執行過程中,因爭奪鎖資源而造成的一種互相等待的現象。

我們一般通過鎖超時機制來解決死鎖。參數為--innodb_lock_timeout. 而設置innodb_print_all_deadlocks 可決定是否將死鎖信息列印到err_log中。

 


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

-Advertisement-
Play Games
更多相關文章
  • 一 環境準備 圖形界面:略 安裝包: linux.x64_11gR2_database_1of2.zip linux.x64_11gR2_database_2of2.zip 二 安裝ASM-Oracle準備 2.1 用戶名/組建立 2.2 相關目錄創建 附:oracle預設不支持CentOS系統安裝 ...
  • 什麼是redis Redis是一種面向“key-value”類型數據的分散式NoSQL資料庫系統,具有高性能、持久存儲、適應高併發應用場景等優勢。它雖然起步較晚,但發展卻十分迅速。 redis為何需要持久化 由於Redis的數據都存放在記憶體中,如果沒有配置持久化,redis重啟後數據就全丟失了,於是 ...
  • MySQL 事務介紹 標簽(空格分隔): Mysql 事務 [TOC] MySQL事務 ACID 1. 原子性(Atomcity) 一個事務的最小單元,要麼全部成功要麼全部失敗,執行的過程中是不能被打斷或者執行其他操作的。 2. 一致性(Consistent) 事務開始前和結束後,資料庫的完整性約束 ...
  • 話不多說先來看看表結構: 顯而易見 Pid 存放的 Person 的 id ;下麵重點(奇葩需求!!!!) 我需要向表一(Person)里插入幾條數據(...)這時候不會對錶二做任何操作。 需求:查詢表一(Person)條件是表二(Person_Visison)里有沒有表一(Person)的 id ...
  • 一 環境準備 安裝包:linux.x64_11gR2_database_1of2.zip linux.x64_11gR2_database_2of2.zip 二 安裝Oracle準備 2.1 用戶名/組建立 2.2 相關目錄創建 提示:oracle預設不支持CentOS系統安裝,需要如下修改 2.3 ...
  • 近期的一個項目要求用mysql資料庫,正好系統重裝了,複習下mysql的安裝,哪成想是踩了無數坑啊! 要安裝首先自然是火速進官網下個安裝包(下載地址https://dev.mysql.com/downloads/file/?id=483327),沒註意mysql都8了,上次安裝的好像是5.幾的。下載 ...
  • redis簡介 Redis 是完全開源免費的,遵守BSD協議,是一個高性能的key value資料庫 Redis 與其他 key value 緩存產品有以下三個特點: Redis支持數據的持久化,可以將記憶體中的數據保存在磁碟中,重啟的時候可以再次載入進行使用 Redis不僅僅支持簡單的key val ...
  • oracle中plsql編程式控制制語句與迴圈語句使用以及具體案例說明 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...