MySQL事物隔離級別詳解

目錄

事物隔離級別總結

實際情況演示

臟讀(未提交)

避免臟讀(讀已提交)

不可重復讀

可重復讀

幻讀


事物隔離級別總結

SQL標準定義了四種事物隔離級別,用來平衡事物的隔離性(Isolation)和并發性能。級別越高,數據一致性越好,但并發性可能越低,這四個級別是:

  • READ-UNCOMMITTED(讀取未提交) :最低的隔離級別,允許讀取尚未提交的數據變更,可能會導致臟讀、幻讀或不可重復讀。這種級別在實際應用中很少使用,因為它對數據一致性的保證太弱。
  • READ-COMMITTED(讀取已提交) :允許讀取并發事務已經提交的數據,可以阻止臟讀但是幻讀或不可重復讀仍有可能發生。這是大多數數據庫(如 Oracle, SQL Server)的默認隔離級別。
  • REPEATABLE-READ(可重復讀)對同一字段的多次讀取結果都是一致的,除非數據是被本身事務自己所修改可以阻止臟讀和不可重復讀,但幻讀仍有可能發生。MySQL InnoDB 存儲引擎的默認隔離級別正是 REPEATABLE READ。并且,InnoDB 在此級別下通過 MVCC(多版本并發控制) 和 Next-Key Locks(間隙鎖+行鎖) 機制,在很大程度上解決了幻讀問題。
  • SERIALIZABLE(可串行化)最高的隔離級別,完全服從 ACID 的隔離級別所有的事務依次逐個執行,這樣事務之間就完全不可能產生干擾,也就是說,該級別可以防止臟讀、不可重復讀以及幻讀

?默認級別查詢:

MySQL InnoDB存儲引擎的默認隔離級別是REPEATABLE READ。可以通過一下命令查看:

mysql> SELECT @@transaction_isolation;
+-------------------------+
| @@transaction_isolation |
+-------------------------+
| REPEATABLE-READ         |
+-------------------------+

?InnoDB 的 REPEATABLE READ 對幻讀的處理:

標準的SQL隔離級別定義里,重復讀是無法防止幻讀的。但InnoDB的實現通過一下機制很大程度上避免了幻讀:

  • 快照讀:普通的SELECT語句,通過MVCC機制實現。事物啟動時創建一個數據快照,后續的快照讀都讀取這個版本的數據,從而避免了看到其他事務新插入到幻讀(幻讀)或修改的行(不可重復讀)。
  • 當前讀: 像SELECT...FOR UPDATE ,SELECT ..LOCK IN SHARE MODE ,INSERT,UPDATE,DELETE這些操作。InnoDB使用Next-Key來鎖定掃描到索引記錄及其間的范圍(間隙),防止其他事務在這個范圍內插入新的記錄,從而避免幻讀。Next-Key Lock是行鎖(Record Lock)和間隙鎖(Gap Lock)的組合。

值得注意的是,雖然通常認為隔離級別越高,并發性越差,但InnoDB存儲引擎通過MVCC機制優化了可重復讀級別。對于常見的只讀或讀多寫少的場景,其性能與讀已提交相比可能沒有顯著差異。不過,在寫密集型且并發沖突較高的的場景下,RR的間隙鎖的機制可能比RC帶來更多的鎖等待。

此外,在某些特定場景下,如需要嚴格一致性分布式事務(XA trransactions),InnoDB可能要求或推薦使用串行化隔離級別來確保原句數據的一致性。

《MySQL 技術內幕:InnoDB 存儲引擎(第 2 版)》7.7 章這樣寫到:

InnoDB存儲引擎提供了對XA事物的支持,并通過XA事務來支持分布式事務的實現。分布式事務指的是允許有多個事務資源(transactions resource)參與到一個全局的事務中。事務資源通常是關系型數據庫系統,但也可以是其他類型的資源。全局事務要求在其中的所有參與的事務要么提交,要么都回滾,這對于事務原有ACID要求又有了提高。另外,在使用分布式事務時,InnoDB存儲引擎的事務隔離級別必須設置為串行化。

實際情況演示

下面會使用2個命令行MySQL,模擬多線程(多事務)對同一份的數據的臟讀問題。

MySQL命令行的默認設置中事務都是自動提交的,即執行SQL語句就會馬上執行COMMIT操作。如果要顯式地開啟一個事務需要使用命令:START TRANSACTION

我們可以通過下面的命令來設置隔離級別。

SET [SESSION|GLOBAL] TRANSACTION ISOLATION LEVEL [READ UNCOMMITTED|READ COMMITTED|REPEATABLE READ|SERIALIZABLE]

?我們再看一下我們在下面實際操作中使用到一些并發控制語句:

  • STRAT TRANSACTION | BEGIN:顯式地開啟一個事務
  • COMMIT:提交事務,使得對數據庫做的修改成為永久性。
  • ROOLBACK:回滾會結束用戶的事務,并撤銷正在進行的所有未提交的修改。

臟讀(未提交)

避免臟讀(讀已提交)

不可重復讀

還是剛才上面的讀已提交的圖,雖然避免了讀未提交,但是出現了,一個事務還沒有結束,就發生了不可重復讀問題。

可重復讀

幻讀

演示幻讀出現的情況

SQL腳本1在第一次查詢工資為500的記錄當時只有一條,SQL腳本2插入了一條工資為500的記錄,提交之后,SQL1腳本在同一個事務中再次出現讀查詢發現了兩條工資為500的記錄這種就是幻讀。

解決幻讀的方法

解決幻讀的方法有很多,但是它們核心的思想就是一個事務在操作某張表數據的時候,另外一個事務不允許新增或者是刪除這張表中的數據了。解決幻讀的方式主要有一下幾種:

  • 將事務隔離級別調整為串行化
  • 在可重復讀的事務級別下,給事務操作的這張表添加表鎖。
  • 在可重復讀的事務級別下,給事務操作的這張表添加Next-Key Lock(Record Lock +Gap Lock)。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/86463.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/86463.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/86463.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【安卓開發】Kotlin入門教程

一、Kotlin 基礎入門 1.1 Kotlin 簡介 Kotlin 是一種由 JetBrains 開發的靜態類型編程語言,運行在 Java 虛擬機上,也可以編譯為 JavaScript 或原生代碼。它于 2017 年被 Google 宣布為 Android 官方開發語言。 主要特點: 簡潔:…

工業機器人保護氣體節約方法

焊接在現代工業生產中作為一項關鍵技術,其效率和質量直接影響著產品的最終性能和生產成本。隨著智能制造的不斷推進,工業焊接機器人在自動化生產線中扮演著越來越重要的角色。焊接過程中的氣體調節一直是一個技術難題,它直接關系到焊接質量的…

java中集合API

集合API 一、簡述二、Collection(1).List1.ArrayList:2. LinkedList (2) Set 三、Map1.HashMap2. TreeMap 三、Iterator接口Collections工具類1.對集合元素進行排序2.基于Comparator,自定義方法(內部類)進行…

Oracle 用戶權限與對象權限詳解

一、權限體系概述 Oracle 數據庫的權限管理是保障數據安全的核心機制,主要分為系統權限(System Privileges) 和對象權限(Object Privileges) 兩大類: 系統權限:賦予用戶在數據庫中執行特定操作…

kubectl get pods 時 “client-side throttling, not priority and fairness“ 原因初探

1. 問題起源 在kubernetes里,使用kubectl get pods 時,返回 I0508 05:43:04.655602 100742 request.go:668] Waited for 1.178494016s due to client-side throttling, not priority and fairness, request: GET:https://10.103.0.1:443/apis/cert-ma…

力扣網C語言編程題:位運算來解決 “尋找重復數”

一. 簡介 前面兩篇文章解決力扣網上"查找重復數"的題目,提供了三種思路:哈希表、二分法和快慢指針。文章如下: 力扣網C語言編程題:“尋找重復數”的兩種思路-CSDN博客 力扣網C語言編程題:快慢指針來解決 …

3D視覺感知

目錄 3D視覺感知任務 單目3D感知 單目3D物體檢測 – 直接預測3D信息 單目3D物體檢測 – 總結 單目深度估計 雙目3D感知 多目3D感知 3D視覺感知任務 ? 輸入:單攝像頭或多攝像頭生成的圖像數據 ? 單張圖像 ? 圖像序列 ? 輸出 ? 稀疏&#xff1a…

es中常規的根據字段查詢時走什么索引(說明:「常規的根據字段查詢」不包含分詞查詢)

在Elasticsearch中,“常規的根據字段查詢”且不涉及分詞的查詢(如精確匹配、范圍查詢),主要依賴以下索引機制: 一、核心索引類型及適用場景 字段類型索引結構典型查詢方式應用場景keyword倒排索引(未分詞…

MYSQL如何插入數據,效率會更高

在MySQL中,插入數據的效率可以通過多種方式逐步提升。以下是從簡單到復雜的優化路徑,幫助你逐步提高數據插入的性能: 一、基礎插入:逐條插入 這是最基礎的插入方式,適用于少量數據的插入操作。雖然簡單,但…

Rabbitmq的五種消息類型介紹,以及集成springboot的使用

交換機類型 Fanout Exchange 扇型交換機,這個交換機沒有路由鍵概念,就算你綁了路由鍵也是無視的。 這個交換機在接收到消息后,會直接轉發到綁定到它上面的所有隊列 Direct Exchange 直連型交換機,根據消息攜帶的路由鍵將消息投遞…

日語學習-日語知識點小記-進階-JLPT-真題訓練-N2階段(4):2022年12月2023年12月

日語學習-日語知識點小記-進階-JLPT-真題訓練-N2階段(4):2022年12月&2023年12月 1、前言(1)情況說明(2)工程師的信仰(3)真題訓練 2、2個卷的單詞部分1、 真題-2023年…

從代碼學習深度強化學習 - Actor-Critic 算法 PyTorch版

文章目錄 前言算法原理1. 從策略梯度到Actor-Critic2. Actor 和 Critic 的角色3. Critic 的學習方式:時序差分 (TD)4. Actor 的學習方式:策略梯度5. 算法流程代碼實現1. 環境與工具函數2. 構建Actor-Critic智能體3. 組織訓練流程4. 主程序:啟動訓練5. 實驗結果總結前言 在深…

Python 數據分析與可視化 Day 8 - Pandas 高級操作技巧

? 今日目標 掌握 Pandas 的索引體系(Index / MultiIndex)使用 set_index() 和 reset_index() 管理數據索引理解 pivot_table 與 melt、stack/unstack 重塑數據形態初步理解“寬表”與“長表”在數據分析與可視化中的應用場景 📚 一、深入理…

Spring Boot整合百度AI人臉比對實戰

目錄 一、簡述 二、依賴 三、代碼步驟 3.1 實體注入 3.2 服務實現 3.3 其它實現 四、小結 歡迎來到 盹貓(>^ω^<)的博客 本篇文章主要介紹了 [Spring Boot整合百度AI人臉比對實戰] ?博主廣交技術好友&#xff0c;喜歡文章的可以關注一下? 一、簡述 人臉識別在日…

使用 pip 安裝 numpy 包卡在 Preparing metadata 階段問題解決

TOC 1 問題描述 使用 pip 安裝numpy卡在下面最后一行的階段&#xff1a; Collecting numpy1.26.4 (from -r requirements.txt (line 2))Using cached https://mirrors.aliyun.com/pypi/packages/65/6e/09db70a523a96d25e115e71cc56a6f9031e7b8cd166c1ac8438307c14058/numpy-…

新手向:Anaconda3的安裝與使用方法

我們在剛開始接觸Python時使用的是Python的直接編譯器,如果我們需要進行其他的項目編寫往往需要使用另一個版本的Python ,這樣反復的下載很是麻煩并且還會造成系統變量的紊亂.這次我們引入Anaconda3,可創建虛擬的Python環境,滿足不同項目的需要,當不用的時候可以直接放心刪除不…

C#中的設計時構造函數

以下是關于設計時構造函數的詳細整理&#xff0c;包括定義、適用場景、相關概念和實際應用&#xff1a; 一、設計時構造函數的定義 設計時構造函數&#xff08;Design-time Constructor&#xff09;是專門為開發工具&#xff08;如Visual Studio、Blazor Designer等&#xff0…

Spring Boot 2.x 項目搭建 (一)

以下是基于Spring Boot 2.x&#xff08;兼容JDK 1.8&#xff09;的項目搭建指南及Markdown文檔生成方案&#xff0c;整合了多個搜索結果中的最佳實踐&#xff1a; 一、項目初始化 1. 使用Spring Initializr創建項目 步驟&#xff1a; 訪問 start.spring.io 或通過IDE&#x…

Kotlin作用域函數:掌握apply/let/run/with/also精髓

一、作用域函數詳解 1. apply&#xff1a;對調用對象進行配置或操作&#xff0c;并返回該對象本身。 接收者引用&#xff1a;this&#xff08;可省略&#xff0c;直接調用接收者成員&#xff09;返回值&#xff1a;接收者對象本身&#xff08;T&#xff09;核心用途&#xff…

Spring Boot監視器:應用監控終極指南

Spring Boot 監視器詳解 Spring Boot 監視器(Monitor)是用于監控和管理 Spring Boot 應用程序運行狀態的核心組件,主要通過 Spring Boot Actuator 和 Spring Boot Admin 兩大工具實現。 一、核心監視器組件 1. Spring Boot Actuator 功能定位:提供應用程序內部運行狀態的原…