MySQL進階:MySQL事務、并發事務問題及隔離級別

👨?🎓作者簡介:一位大四、研0學生,正在努力準備大四暑假的實習、
🌌上期文章:MySQL進階:視圖&&存儲過程&&存儲函數&&觸發器
📚訂閱專欄:MySQL進階
希望文章對你們有所幫助

這一部分內容還是很重要的,雖然學起來感覺不是很難,但是要多體會一下,體會好這里的精髓才能更好的理解MySQL事務的鎖。

MySQL事務及隔離級別

  • 簡介
  • 事務操作
    • 未控制事務
    • 控制事務一
    • 控制事務二
  • 事務四大特性(高頻面試題)
  • 事務并發問題(重點)
  • 事務隔離級別

簡介

事務是一組操作的集合,它是一個不可分割的工作單位,事務會把所有的操作作為一個整體一起向系統提交或撤銷操作請求,即這些操作要么同時成功,要么同時失敗。
就比如轉賬,包括加錢和減錢的操作,這一組操作必須在一個事務的范圍內,要么都成功,要么都失敗。

默認MySQL的事務是自動提交的,也就是說,當執行完一條DML語句時,MySQL會立即隱
式的提交事務。

事務操作

create table account(id int primary key AUTO_INCREMENT comment 'ID',name varchar(10) comment '姓名',money double(10,2) comment '余額'
) comment '賬戶表';
insert into account(name, money) VALUES ('張三',2000), ('李四',2000);

未控制事務

-- 1. 查詢張三余額
select * from account where name = '張三';
-- 2. 張三的余額減少1000
update account set money = money - 1000 where name = '張三';
出錯了....
-- 3. 李四的余額增加1000
update account set money = money + 1000 where name = '李四';

"出錯了…"這句話會報錯,若不加事務,就會導致張三的錢減少,但是李四的錢沒有增加,這就違背了數據一致性

控制事務一

1、查看/設置事務提交方式

SELECT @@autocommit ;
SET @@autocommit = 0 ;

2、提交事務

COMMIT;

3、回滾事務

ROLLBACK;

上述的這種方式,是修改了事務的自動提交行為, 把默認的自動提交修改為了手動提交, 此時我們執行的DML語句都不會提交, 需要手動的執行commit進行提交。

控制事務二

1、開啟事務

BEGIN;START TRANSACTION;

2、提交事務

COMMIT;

3、回滾事務

ROLLBACK;

事務四大特性(高頻面試題)

  • 原子性:事務是不可分割的最小單元,要么全成功要么全失敗
  • 一致性:事務完場時,必須使所有數據保持一致狀態
  • 隔離性:數據庫系統提供的隔離機制,保證事務在不受外部并發操作影響的獨立環境下運行
  • 持久性:事務一旦提交或回滾,對數據庫中的數據的改變是永久的

事務的四大特性,簡稱ACID。

事務并發問題(重點)

1、臟讀:一個事務讀到另外一個事務還沒有提交的數據。
在這里插入圖片描述
B事務的select操作讀取到了DB中id=1的數據,但讀出來的是事務A執行update后的數據,但事務A根本還沒有提交事務。

2、不可重復讀:一個事務先后讀取同一條記錄,但兩次讀取的數據不同,稱之為不可重復讀。
在這里插入圖片描述
注意:假設此時已經解決了事務的臟讀問題
事務A兩次讀取同一條記錄,但是讀取到的數據卻是不一樣的。這是因為在兩次select操作之間有一個事務B提交了,事務就是將這一行的數據修改了。

3、幻讀:一個事務按照條件查詢數據時,沒有對應數據行,但是在插入數據時,又發現這行數據已經存在,好像出現了“幻影”。
在這里插入圖片描述
注意:假設此時已經解決了事務的臟讀問題和不可重復讀問題

1、事務A執行select,確認了數據庫沒有id=1的數據
2、事務B執行insert,數據庫中增加了id=1的數據
3、事務A執行insert,由于id=1的數據已經存在,無法插入
4、事務A再次執行select,由于已經解決了不可重復讀的問題,此時事務A還是沒辦法獲取到id=1的數據

這就是幻讀,明明查不到,卻插入不進去。

事務隔離級別

為了解決并發事務問題,數據庫中引入了事務的隔離級別:

隔離級別臟讀不可重復讀幻讀
Read uncommitted
Read commited×
Repeatable Read(默認)××
Serializable×××

1、查看事務的隔離級別:

SELECT @@TRANSACTION_ISOLATION;

2、設置事務隔離級別:

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

需要注意的是,事務的隔離級別越高,數據自然越安全,但是性能會更低。

在這里我們可以看到,MySQL默認的事務隔離級別是RR,臟讀和不可重復讀的問題是已經解決了,但幻讀問題的解決方法是要加一個行級鎖——間隙鎖&臨鍵鎖。

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

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

相關文章

Docker Machine windows系統下 安裝

如果你是 Windows 平臺,可以使用 Git BASH,并輸入以下命令: basehttps://github.com/docker/machine/releases/download/v0.16.0 &&mkdir -p "$HOME/bin" &&curl -L $base/docker-machine-Windows-x86_64.exe >…

點燃技能火花:探索PyTorch學習網站,開啟AI編程之旅!

介紹:PyTorch是一個開源的Python機器學習庫,它基于Torch,專為深度學習和科學計算而設計,特別適合于自然語言處理等應用程序。以下是對PyTorch的詳細介紹: 歷史背景:PyTorch起源于Torch,一個用于…

【真機Bug】異步加載資源未完成訪問單例導致資源創建失敗

1.錯誤表現描述 抽卡時,10抽展示界面為A。抽取內容可能是整卡或者碎片,抽到整卡,會有立繪展示和點擊詳情的按鈕。點擊詳情后出現詳情頁B。【此時界面A預制體被銷毀,卡片數據進入數據緩存池】點擊頁面B的返回按鈕,單例…

C++——模版

前言:哈嘍小伙伴們好久不見,這是2024年的第一篇博文,我們將繼續C的學習,今天這篇文章,我們來習一下——模版。 目錄 一.什么是模版 二.模版分類 1.函數模版 2.類模板 總結 一.什么是模版 說起模版,我們…

線索二叉樹

線索二叉樹即從前、中、后序三種遍歷中其中一種來看,樹中的左右孩子都不會是空著的,都會指向對應的前驅和后驅。 以中序遍歷為例,二叉樹線索化過程如下: 先是樹的結構 typedef struct ThreadNode{Elemetype data;struct ThreadNo…

微服務面試題之套路一

面試題 一、你的項目是從SpringBoot演進到微服務架構的,你在此過程中有調研過哪些技術,怎么調研落地的? 微服務通信框架: 需要選擇適合項目的微服務通信框架,如Dubbo、Spring Cloud或gRPC Feign RestTemplate 等。調研方式可以是…

高性能通信之Netty

一, 同步IO(BIO)模型的架構 一般針對性能不高的情況下可以使用. 二,異步IO(NIO)模型的架構 多路復用(epoll模型):

【LeetCode:124. 二叉樹中的最大路徑和 + 二叉樹+遞歸】

🚀 算法題 🚀 🌲 算法刷題專欄 | 面試必備算法 | 面試高頻算法 🍀 🌲 越難的東西,越要努力堅持,因為它具有很高的價值,算法就是這樣? 🌲 作者簡介:碩風和煒,…

前端開發人員如何做好SEO

前端開發人員如何做好SEO SEO工作不僅限于專業人員。前端開發者也可以在日常開發中實施一些代碼層面的SEO優化。 以下是一些前端常用的SEO方法: 設置合理的title、keywords、description title、keywords、description對SEO至關重要,需貼合頁面內容編…

Codeforces Round 931 (Div. 2) (A~B)

比賽:Codeforces Round 931 (Div. 2) (A~B) 目錄:A B A題:Too Min Too Max 標簽: 構造算法(constructive algorithms)貪心(greedy)數學(math) 題目大意 對數組 a 找到…

【力扣hot100】刷題筆記Day19

前言 回溯回溯回溯!早上整理檔案竟然用了桶排序,不愧是算法狂魔們 79. 單詞搜索 - 力扣(LeetCode) DFS class Solution:def exist(self, board: List[List[str]], word: str) -> bool:m, n len(board), len(board[0])# used…

mysql timestamp轉換為datetime

MySQL timestamp轉換為datetime的方法 1. 流程概述 在MySQL中,timestamp和datetime是兩種不同的數據類型。timestamp存儲了日期和時間,并且會自動更新,可以用于記錄數據的創建和修改時間。datetime則是一個固定的日期和時間,不會自…

談談高并發系統的設計方法論

談談高并發系統的設計方法論 何為高并發系統?什么是并發(Conurrent)?什么是高并發(Hight Concurrnet)?高并發的衡量指標有哪些? 實現高并發系統的兩大板塊高并發系統應用程序側的設計…

騰訊云學生服務器使用教程_申請騰訊云學生機詳細流程

2024年騰訊云學生服務器優惠活動「云校園」,學生服務器優惠價格:輕量應用服務器2核2G學生價30元3個月、58元6個月、112元一年,輕量應用服務器4核8G配置191.1元3個月、352.8元6個月、646.8元一年,CVM云服務器2核4G配置842.4元一年&…

還在用Jenkins?快來試試這款簡而輕的自動部署軟件!

最近發現了一個比 Jenkins 使用更簡單的項目構建和部署工具,完全可以滿足個人以及一些小企業的需求,分享一下。 Jpom 是一款 Java 開發的簡單輕量的低侵入式在線構建、自動部署、日常運維、項目監控軟件。 日常開發中,Jpom 可以解決下面這些…

Nginx的多線程支持探究

文章中心思想: Nginx本身并不直接支持多線程處理模型。它采用的是基于事件驅動的單線程或多進程架構,而非多線程模型。然而,通過Nginx的模塊和第三方擴展,可以實現類似多線程的并發處理效果。 詳細說明: Nginx,作為一款高性能的Web服務器和反向代理服務器,其架構和并發…

章節二、three.js開發入門與調試設置02;

一、軌道控制器查看物體; 1、基本概念 軌道控制器(OrbitControls)可以使得相機圍繞目標進行軌道運動; 2、代碼樣例 // 七、創建軌道控制器(相機圍繞著物體捕捉視角) const controls new OrbitControls(c…

吳恩達機器學習全課程筆記第五篇

目錄 前言 P80-P85 添加數據 遷移學習 機器學習項目的完整周期 公平、偏見與倫理 P86-P95 傾斜數據集的誤差指標 決策樹模型 測量純度 選擇拆分方式增益 使用分類特征的一種獨熱編碼 連續的有價值特征 回歸樹 前言 這是吳恩達機器學習筆記的第五篇&#xff0c…

《2023跨境電商投訴大數據報告》發布|亞馬遜 天貓國際 考拉海購 敦煌網 阿里巴巴

2023年,跨境電商API接口天貓國際、京東國際和抖音全球購以其強大的品牌影響力和市場占有率,穩坐行業前三的位置。同時,各大跨境電商平臺消費糾紛問題層出不窮。依據國內知名網絡消費糾紛調解平臺“電訴寶”(315.100EC.CN&#xff…

javaEE--后端環境變量配置

目錄 pre 文件準備 最終運行成功結果 后端運行步驟 1.修改setenv文件 2.運行setenv,設置環境變量 3.查看jdk版本 4.修改mysql文件夾下的my文件 前端運行步驟 1.nodejs環境配置 2.查看node和npm版本 3.下載并運行npm 4.注冊登錄 pre 文件準備 最終運行…