MySQL事務與併發

来源:https://www.cnblogs.com/lyuzt/archive/2020/04/30/12810150.html
-Advertisement-
Play Games

很多程式員都學過MySQL,而且也會寫SQL語句。但僅僅會寫還遠遠不夠,在面試中以及在工作中,還必須要會事務和併發。 一、事務 事務是滿足 ACID 特性的操作,可以通過 Commit 提交事務,也可以使用 Rollback 進行回滾。 A(Atomicity)原子性:事務被視為不可分割的小單元,事 ...


  很多程式員都學過MySQL,而且也會寫SQL語句。但僅僅會寫還遠遠不夠,在面試中以及在工作中,還必須要會事務和併發。

一、事務

事務是滿足 ACID 特性的操作,可以通過 Commit 提交事務,也可以使用 Rollback 進行回滾。 A(Atomicity)原子性:事務被視為不可分割的小單元,事務的所有操作要麼全部提交成功,要麼全部失敗回滾。 C(Consistency)一致性:資料庫在事務執行前後都保持一致性狀態。在一致性狀態下,所有事務對一個數據的讀取結果都是相同的。 I(Isolation)隔離性:事務之間的操作是相互隔離的。 D(Durability)持久性:一旦事務提交,則其所做的修改將會永遠保存到資料庫中。

二、併發一致性

在併發環境下,容易造成併發一致性問題,導致隔離性被破壞。假設目前有兩個事務,分別命名為A和B,在併發環境下,容易出現以下問題。 丟失更新:A、B同時修改數據,A先,B後,A提交後B提交,B操作覆蓋了A的操作,導致A丟失更新。 讀臟數據:A修改數據,B讀取數據;隨後A撤銷操作,則B讀到臟數據。 不可重覆讀:B讀取數據,A修改數據,B再次讀取數據,發現數據和第一次讀時不一致。 幻讀:A讀取了某個範圍的數據,B在此範圍內插入一條數據;A再次讀取,結果不一樣。

三、鎖

在併發環境下,為解決併發一致性問題保證事務的隔離性,可採取封鎖機制。當一個事務在進行操作時加鎖,限制另一個事務的操作。 一般而言,為保證效率,鎖的粒度不宜太大。在MySQL中,提供了行鎖表鎖 行鎖:事務A操作數據時,只封鎖被操作的行,事務B可以操作其他行的數據,併發程度高; 表鎖:事務A操作數據時,封鎖整個表,事務B要等A完成才能操作,併發度較低。   在讀寫方面資料庫鎖也分為讀鎖(共用鎖)寫鎖(排他鎖) 讀鎖:若事務A加了此鎖,A可以對數據進行讀取操作,但不能更新;其它事務也可以讀,但不能修改; 寫鎖:若事務A加了此鎖,A可以對數據進行讀和寫操作,其它事務不能讀寫,否則會阻塞。   上面所說的是悲觀鎖,MySQL中InnoDB也提供了樂觀鎖的實現——MVCC(多版本併發控制)。用通俗的方式解釋悲觀鎖和樂觀鎖大概是這樣: 悲觀鎖:認為每次操作都會修改數據,每次都在操作前上鎖;​ 樂觀鎖:認為每次操作都不會修改數據,不上鎖,但是會記錄一個版本號或者時間戳,用來對比。 MVCC則是樂觀鎖的實現,它在每行記錄後面都保存著兩個隱藏的列,用來存儲創建版本號刪除版本號

四、隔離級別

若鎖的操作要用戶自己控制,會比較複雜,因此資料庫管理系統提供了事務的隔離級別,使問題簡單化。MySQL的隔離級別有四種,分別是:未提交讀、已提交讀、可重覆讀、可序列化。它們與併發一致性問題的關係如下表所示。MySQL預設隔離級別為:可重覆讀 未提交讀:事務修改數據,即使未提交,其它事務依舊可見。 已提交讀:事務修改數據提交之前,其他事務不可見。 可重覆讀:事務多次讀取數據的結果都一樣。 可序列化:解決了幻讀問題。

五、存儲引擎

說到資料庫的併發問題,就要提一下MySQL的存儲引擎。MySQL的存儲引擎有很多種,最常用的還是MyISAMInnoDB,它們的區別如下: 因此,一般在讀操作比較多的情況下,MyISAM的效率更高,因為相比於InnoDB,它維護的東西要少,比如版本號,索引數據等。 但是InnoDB支持事務,而且在併發環境下優勢顯著。至於如何選擇存儲引擎,應根據具體情況而定。

總結

本文講了資料庫的事務以及併發一致性問題,並且引申出解決辦法以及MySQL的存儲引擎。這些知識,對於絕大多數從事互聯網工作的人來說,是必須要掌握的,也是在面試中經常考察的點。  

如果覺得對你有幫助,可以關註公眾號:Max的日常操作,或掃碼關註

                          


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

-Advertisement-
Play Games
更多相關文章
  • #include "ioCC2530.h" #define D3 P1_0#define D4 P1_1#define D5 P1_3#define D6 P1_4#define SW1 P1_2 unsigned char count_t = 0; //長定時累計變數unsigned char K ...
  • 一、編寫拆分腳本(splitNginxLog.sh) #!/bin/bash year=`date +%Y` month=`date +%m` day=`date +%d` # 原始日誌路徑 logs_path="/var/log/nginx/sitename.com/" # 日誌備份路徑 logs ...
  • 首先解釋一下 橋接模式:在該模式下,開啟的虛擬機相當於區域網中的一臺物理機,在該虛擬機開啟的服務,區域網的機器可以直接用 虛擬機ip + 埠直接訪問。 NAT模式:就是在宿主機內部的一臺虛機機,公用宿主機的網路。該虛擬機開啟的服務,宿主機可以通過 虛擬機ip + 埠直接訪問,但是區域網的機器無法 ...
  • [TOC] 前言 DDL DDL,中文為數據定義語言,DDL的特點是對資料庫內部的對象進行create(創建)、alter(修改)、drop(刪除)等操作,負責管理資料庫的基礎數據,不涉及對錶中內容的操作和更改。 DCL DCL,中文為數據控制語言,DDL的特點是對資料庫內部的對象grant(用戶授 ...
  • 當安裝alluxio時,出現允許打開的文件數目過小問題: The user limit for number of open files is too small. The current value is 4096. For production use, it should be bigger ...
  • [TOC] MySQL全庫備份腳本 ...
  • 本文主要介紹 COM 的基礎知識,傾向於理論性的理解,面向初學者,淺嘗輒止。 1. COM 是什麼: COM 的英文全稱是,Component Object Model,中文譯為,組件對象模型。它官方的概念是:The Microsoft Component Object Model (COM) is ...
  • 1、索引 1-1、索引的概述 我們把一個表中的一列或者多列和列中元素所在表中記錄的物理地址組合成一個新的表。這個表的記錄大致為列的內容和該列所在記錄的物理地址。 1-2、索引的優缺點 www.2cto.com 優點:大大加快了對源表的執行速度,我們對索引表的檢索就可以實現對源表的檢索。到底快在哪裡? ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...