【MySQL】資料庫事務深入分析

来源:https://www.cnblogs.com/wangzhongqiu/archive/2019/08/17/11370606.html
-Advertisement-
Play Games

一、前言 只有InnoDB引擎支持事務,下邊的內容均以InnoDB引擎為預設條件 二、常見的併發問題 1、臟讀 一個事務讀取了另一個事務未提交的數據 2、不可重覆讀 一個事務對同一數據的讀取結果前後不一致。兩次讀取中間被其他事務修改了 3、幻讀 幻讀是指事務讀取某個範圍的數據時,因為其他事務的操作導 ...


一、前言

只有InnoDB引擎支持事務,下邊的內容均以InnoDB引擎為預設條件

二、常見的併發問題

1、臟讀

一個事務讀取了另一個事務未提交的數據

2、不可重覆讀

一個事務對同一數據的讀取結果前後不一致。兩次讀取中間被其他事務修改了

3、幻讀

幻讀是指事務讀取某個範圍的數據時,因為其他事務的操作導致前後兩次讀取的結果不一致。幻讀和不可重覆讀的區別在於,不可重覆讀是針對確定的某一行數據而言,而幻讀是針對不確定的多行數據。因而幻讀通常出現在帶有查詢條件的範圍查詢中

三、事務隔離級別

1、讀未提交(READ UNCOMMITTED)

可能產生臟讀、不可重覆讀、幻讀

2、讀已提交(READ COMMITTED)

避免了臟讀,可能產生不可重覆讀、幻讀

3、可重覆讀(REPEATABLE READ)(mysql預設隔離級別)

避免了臟讀,不可重覆讀。通過區間鎖技術避免了幻讀

4、串列化(SERIALIZABLE)

串列化可以避免所有可能出現的併發異常,但是會極大的降低系統的併發處理能力

四、資料庫日誌有哪些?

1、undo日誌

undo日誌用於存放數據修改被修改前的值

UNDO LOG中分為兩種類型,一種是 INSERT_UNDO(INSERT操作),記錄插入的唯一鍵值;

一種是 UPDATE_UNDO(包含UPDATE及DELETE操作),記錄修改的唯一鍵值以及old column記錄。

2、redo日誌

mysql會將一個事務中的所有sq先l記錄到redo log中,然後再將記錄從redo log同步到數據文件中

它可以帶來這些好處:

  • 當buffer pool中的dirty page 還沒有刷新到磁碟的時候,發生crash,啟動服務後,可通過redo log 找到需要重新刷新到磁碟文件的記錄;
  • buffer pool中的數據直接flush到disk file,是一個隨機IO,效率較差,而把buffer pool中的數據記錄到redo log,是一個順序IO,可以提高事務提交的速度;

3、binlog日誌

用於資料庫主從複製的記錄,是二進位格式。在事務提交之後進行一個磁碟寫入。

這裡註意下redo log 跟binary log 的區別,redo log 是存儲引擎層產生的,而binary log是資料庫層產生的。假設一個大事務,對tba做10萬行的記錄插入,在這個過程中,一直不斷的往redo log順序記錄,而binary log不會記錄,直到這個事務提交,才會一次寫入到binary log文件中

五、資料庫事務控制

1、預設情況下,開啟事務自動提交功能。每執行一個sql,都會對應一個事務的提交

2、spring會將底層連接的自動提交特性設置為false。使用手動提交

六、事務的ACID特性

1、原子性(Atomicity)

事務中的所有操作作為一個整體像原子一樣不可分割,要麼全部成功,要麼全部失敗。

2、一致性(Consistency)

事務的執行結果必須使資料庫從一個一致性狀態到另一個一致性狀態。一致性狀態是指:1.系統的狀態滿足數據的完整性約束(主碼,參照完整性,check約束等) 2.系統的狀態反應資料庫本應描述的現實世界的真實狀態,比如轉賬前後兩個賬戶的金額總和應該保持不變。

3、隔離性(Isolation)

併發執行的事務不會相互影響,其對資料庫的影響和它們串列執行時一樣。比如多個用戶同時往一個賬戶轉賬,最後賬戶的結果應該和他們按先後次序轉賬的結果一樣。

4、持久性(Durability)

事務一旦提交,其對資料庫的更新就是持久的。任何事務或系統故障都不會導致數據丟失。

5、redo log和undo log實現了原子性、一致性、持久性

6、鎖機制實現了隔離性

6.1、快照讀

讀取的是快照版本,也就是歷史版本。普通的SELECT就是快照讀

6.2、當前讀

讀取的是最新版本。UPDATE、DELETE、INSERT、SELECT ...  LOCK IN SHARE MODE、SELECT ... FOR UPDATE是當前讀。

6.3、鎖定讀

  在一個事務中,標準的SELECT語句是不會加鎖,但是有兩種情況例外。SELECT ... LOCK IN SHARE MODE 和 SELECT ... FOR UPDATE。

  SELECT ... LOCK IN SHARE MODE

  給記錄假設共用鎖,這樣一來的話,其它事務只能讀不能修改,直到當前事務提交

  SELECT ... FOR UPDATE

  給索引記錄加鎖,這種情況下跟UPDATE的加鎖情況是一樣的

6.4、一致性非鎖定讀

  consistent read (一致性讀),InnoDB用多版本來提供查詢資料庫在某個時間點的快照。如果隔離級別是REPEATABLE READ,那麼在同一個事務中的所有一致性讀都讀的是事務中第一個這樣的讀讀到的快照;如果是READ COMMITTED,那麼一個事務中的每一個一致性讀都會讀到它自己刷新的快照版本。Consistent read(一致性讀)是READ COMMITTED和REPEATABLE READ隔離級別下普通SELECT語句預設的模式。一致性讀不會給它所訪問的表加任何形式的鎖,因此其它事務可以同時併發的修改它們。

 


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

-Advertisement-
Play Games
更多相關文章
  • 前言 我們目前已經學習了設計模式的7種設計原則。下麵本該是直接進入具體的設計模式系列文章。 但是呢在我們學習設計模式之前我們還是有必要瞭解一下uml圖。因為後續的設計模式文章不出意外應該會很多地方使用到uml圖。如果你連uml圖都看不懂的話,那麼學習起來肯定會有一定的難度。 所以說,這一節就作為承上 ...
  • 1. new一個對象在Java內部做了哪些工作? 從靜態角度來看,new一個對象表示創建一個類的對象實例。 從JVM運行角度來看,當JVM執行到new位元組碼時,首先會去查看類有沒有被載入到記憶體以及初始化,如果是第一次使用該類,則首先載入該類。載入完成後便會在堆記憶體分配該對象實例的記憶體空間,虛擬機棧分 ...
  • 1.目前PyOpenGL是用python2寫的,如果你使用的是python3需要自己修改PyOpenGL,我這裡使用的是python2.7 2.下載PyOpenGLhttps://pypi.org/project/PyOpenGL/3.1.0/#modal-close,下載對應系統版本的就可以 3. ...
  • 一、 例子:我們對傳參是有要求的必須傳入一個元組,否則報錯 二、 二、threading的使用 直接利用threading.Thread生成Thread的實例 格式: t= threading.Thread(target=函數體,args=(,))#參數args要傳遞元組 ​t.start()#啟動 ...
  • 1 字元串、數組、集合的轉換 定義字元串數組 String[] strArr 1.1 字元串數組轉集合 1.2 字元串集合轉數組 1.3 字元串集合轉逗號分隔的字元串 1.4 逗號分隔的字元串轉字元串集合 1.5 對象集合轉 Map 定義對象 Person 定義對象 Person 的集合 List ...
  • 限流演算法 計數器限流 固定視窗 滑動視窗 桶限流 令牌桶 漏桶 計數器 計數器限流可以分為: 固定視窗 滑動視窗 固定視窗 固定視窗計數器限流簡單明瞭,就是限制單位之間內的請求數,比如設置QPS為10,那麼從一開始的請求進入就計數,每次計數前判斷是否到10,到達就拒絕請求,並保證這個計數周期是1秒, ...
  • 一般我們不把資料庫的配置信息寫死在代碼中。 寫好代碼後,編譯、調試,成功後只把輸出目錄中的東西(jar包、.class文件、資源文件等)拷貝到伺服器上,由運維來管理。伺服器上是沒有源文件的(.java文件),我們我們把資料庫的配置信息寫死在代碼中,運維就不能修改資料庫的配置了,如果要換伺服器、要換數 ...
  • 串口調試助手 該程式使用Qt框架,C ++語言編譯而成 項目文件介紹: 該文件中獲取串口是通過讀取Windows系統下的註冊表中的信息得到的, - 使用Qt中的定時器來每個3s讀取一次註冊表 串口通信方面:通過使用Qt的封裝的QSerialPort來實現 main.cpp mainwindow.h ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...