【後端面經-資料庫】MySQL的事務隔離級別簡介

来源:https://www.cnblogs.com/CrazyPixel/archive/2023/06/14/17481063.html
-Advertisement-
Play Games

[TOC](【後端面經-資料庫】MySQL的事務隔離級別簡介) ## 0. 事務的概念 事務指的是一連串的集中操作指令,一個事務的執行必須執行完所有的動作才能算作執行結束。事務具有四個特點,簡記作`ACID`: - `A`-Atomicity: 原子性,事務的執行必須保證所有的動作都執行完畢; - ...


目錄

0. 事務的概念

事務指的是一連串的集中操作指令,一個事務的執行必須執行完所有的動作才能算作執行結束。事務具有四個特點,簡記作ACID

  • A-Atomicity: 原子性,事務的執行必須保證所有的動作都執行完畢;
  • C-Consistency: 一致性,事務的執行必須保證數據的一致性;
  • I-Isolation: 隔離性,事務的執行必須保證數據的隔離性;
  • D-Durability: 持久性,事務的執行必須保證數據的持久性。

而事務隔離級別則是在大型資料庫多個事務執行的過程中,針對事務並行進行的機制設計,主要是圍繞Isolation進行設計的。

1. 三類問題

  1. 臟讀
    • 過程:
      • 事務A正在寫某一行數據,未提交;
      • 事務B並行讀取該行數據,用於操作;
      • 事務A撤銷寫操作,這是對於事務B來說,之前的讀操作就是錯誤的。
    • 讀事務讀取了寫事務未提交的數據,而造成錯誤讀取。
    • 舉例
      • 小明今天發工資,一開始在財務系統上查詢是工資50000元,很高興地準備買新電腦,但是這是財務正在敲數據的時候一時疏忽,實際上工資只有5000元,財務在審核數據準備提交的時候發現了這個錯誤並修改過來,小明很失望。
      • 這裡的小明就是讀事務,財務就是寫事務
  2. 不可重覆讀
    • 過程:
      • 事務B讀取的是資料庫中的某一行數據,用於操作;
      • 事務A開始對這行數據進行寫操作並完成,資料庫的數據改變;
      • 事務B再次讀該資料庫的這一行數據,發現數據改變;
    • 讀事務兩次讀同一行數據,但是兩次讀取的數據並不一致。
    • 舉例
      • 小明和小紅打賭,這個月工資是1k,兩個人幾乎同時發出查詢請求,但是小明先讀取到了原始數據是1k,而財務核對之後再次修改了工資為2k,小紅在這之後才併發讀取到工資是2k,兩人認為讀操作是並行的,同時進行,雖然知道這中間可能是財務進行了修改,但是兩人都認為自己讀取的才是最終數據,因此吵了起來。
  3. 幻讀
    • 過程
      • 事務B讀取資料庫中的一批數據,用於操作;
      • 事務A添加了一行數據,並完成操作,資料庫的數據改變;
      • 事務B再次讀該資料庫的數據,發現這一批數據改變;
    • 讀事務兩次讀取同一行數據,但是兩次讀取的數據不一致。(這和不可重覆讀操作是一致的)。
    • 舉例
      • 小明被領導要求,改動財務系統上的ID數據格式,從A格式全都轉為B格式,小明讀取資料庫中的數據之後開始修改,這時候,財務發現新來了一位員工叫小紅,於是把小紅的記錄添加在財務系統上,ID格式依然是A格式。小明工作完成之後給領導看,領導卻發現有一個人的數據沒有改過來,很是惱火,把小明批評了一番。
    • 幻讀和不可重覆讀的區別
      • 幻讀是針對同一批數據,不可重覆讀針對的是同一行數據

2. 事務隔離級別

  1. 讀未提交(read uncommitted)
  • 一個事務在寫某一行數據的時候,允許其他事務並行讀取該行數據,但是不允許寫該行數據;
  • 允許多個事務並行讀取資料庫中的數據,但是不允許並行寫入某一行數據;
  • 可能會出現臟讀:
  • 解決方案:排他鎖
  1. 讀已提交(read committed)

    • 一個事務在寫某一行數據的時候,不允許其他事務讀或者寫該行數據;
    • 允許多個事務並行讀取資料庫的數據;
    • 可能都造成不可重覆讀
  2. 可重覆讀(repeatable read)

    • 一個事務在讀數據的時候,其他事務不允許寫,可以讀。
    • 一個事務在寫數據的時候,其他事務不可以讀或者寫。
    • 可能會造成幻讀
    • MySQL預設的隔離級別。
  3. 串列化(serializable)

    • 一個事務一個事務串列執行,不允許任何事物並行;
    • 能夠解決幻讀不可重覆讀臟讀的問題;
    • 成本高,一般不適用

3. 操作指令

  1. 查看當前的隔離級別
    SELECT @@tx_isolation;
    
  2. 設置隔離級別
     set  [glogal | session]  transaction isolation level 隔離級別名稱;//方式1
     set tx_isolation='隔離級別名稱';//方式2
    ``
    

4. 總結

對前期的事務隔離級別做一個表格梳理
img

5. 參考博文

  1. 參考博文-1
  2. 參考博文-2

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

-Advertisement-
Play Games
更多相關文章
  • 本篇為學習李應保老師所著的《WPF專業編程指南》並搭配`WPF`開發聖經《WPF編程寶典第4版》以及痕跡大佬《WPF入門基礎教程系列》文章所作筆記,對應《WPF專業編程指南》第 9-10 章之間內容,主要概述`WPF`中關於樣式及模板部分的梳理及示例應用,希望可以幫到大家
  • 前一段時間有網友問Excel轉pdf怎麼轉pdf,小編幫他實現了一個,方法是使用EPPlus和PdfSharp組件實現,由於依賴OfficeOpenXml他也沒有用上,後來小編又實現了二種不依賴OfficeOpenXml的方法。本文將介紹這三種方法實現Excel轉pdf。 **一、EPPlus和Pd ...
  • 1. 什麼是泛型 編寫一個方法,實現兩數相加並返回結果。 作用 泛型增強了代碼的可讀性 泛型有助於實現代碼的重用、保護類型的安全以及提高性能。 我們可以創建泛型集合類。 泛型實現了類型和方法的參數化 我們還可以對泛型類進行約束以訪問特定數據類型的方法。 關於泛型數據類型中使用的類型的信息可在運行時通 ...
  • 大家好,我是 god23bin。歡迎來到《一分鐘學一個 Linux 命令》系列,每天只需一分鐘,記住一個 Linux 命令不成問題。今天需要你花兩分鐘時間來學習下,因為今天要介紹的是兩個常用的搜索命令:find 和 grep 命令。 ...
  • # ssh免密登錄、伺服器安全 ## ssh免密登錄 > 1. 客戶端本地生成一對公鑰 > > ``` > ssh-keygen -t rsa > ``` > > 2. 客戶端發送自己的公鑰,發給伺服器,存在伺服器的authorized_keys文件中 > > ``` > ssh-copy-id r ...
  • 之前新東方的老師分享了他們通過 Telegraf、Loki、Nightingale 等工具來監控機器硬體狀態的方案,具備很強的靈活性、平臺性。本文會介紹一個相對輕量的方式,只需要一個二進位+一個腳本即可搞定,給各位朋友提供一種新的選擇 ...
  • # DNS功能變數名稱解析 ## 1、nslookup > 通過nslookup命令查看功能變數名稱的解析關係 > > 1.該命令需要單獨安裝dns的套件軟體包 > > yum install bind-utils -y > > 2.使用nslookup命令 > > nslookup > > www.baidu.c ...
  • # NFS遠程掛載 ## 一、概述 > NFS是一種基於TCP/IP 傳輸的網路文件系統協議。通過使用NFS協議,客戶機可以像訪問本地目錄一樣訪問遠程伺服器中的共用資源 > NAS存儲: NFS服務的實現依賴於RPC (Remote Process Call,遠端過程調用)機制,以完成遠程到本地的映 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...