成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

一文帶你搞懂MySQL的事務(wù)隔離級(jí)別

瀏覽:2日期:2023-07-20 19:52:12
目錄一、并行事務(wù)會(huì)有什么問題?1.1 臟寫1.2 臟讀1.3 不可重復(fù)讀1.4 幻讀1.5 區(qū)別二、事務(wù)隔離級(jí)別一、并行事務(wù)會(huì)有什么問題?

在講事務(wù)隔離級(jí)別之前,我們先想一下,如果有多個(gè)事務(wù)并行執(zhí)行,MySQL數(shù)據(jù)最終會(huì)有什么問題?

可以說,事務(wù)的存在都是為了防止并發(fā)問題,我們的MySQL數(shù)據(jù)庫(kù)可以同時(shí)接受多個(gè)client連接,即支持同時(shí)多個(gè)事務(wù)處理,當(dāng)多個(gè)事務(wù)同時(shí)進(jìn)行的時(shí)候,可能會(huì)出現(xiàn)以下等問題:

臟寫(dirty write)

臟讀(dirty read)

不可重復(fù)讀(non-repeatable read)

幻讀(phantom read)

1.1 臟寫

臟寫 *(dirty write) *,直白說就是兩個(gè)事務(wù)同時(shí)更新一行數(shù)據(jù),事務(wù)A回滾把事務(wù)B的值覆蓋了,實(shí)質(zhì)就是兩個(gè)未提交的事務(wù)互相影響。

舉個(gè)例子, 現(xiàn)在有一張表:

CREATE TABLE `bank_balance` ( `id` int NOT NULL AUTO_INCREMENT, `user_name` varchar(45) NOT NULL COMMENT '用戶名', `balance` int NOT NULL DEFAULT '0' COMMENT '余額,單位:人民幣分,比如100表示人民幣1元,默認(rèn)是0', `wealth` tinyint NOT NULL DEFAULT '0' COMMENT '富有程度,0:貧窮,1:富有', PRIMARY KEY (`id`), UNIQUE KEY `idx_bank_balance_user_name` (`user_name`)) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

表中有一行id=3 且 user_name=Tom的記錄:

mysql> select id,user_name,balance from bank_balance where user_name = 'Tom';+----+-----------+---------+| id | user_name | balance |+----+-----------+---------+| 3 | Tom | 100 |+----+-----------+---------+1 row in set (0.00 sec)

現(xiàn)在有兩個(gè)事務(wù),事務(wù)A和事務(wù)B,事務(wù)A是給Tom賬戶余額加100,事務(wù)B是給Tom賬戶余額加200。

在①處,事務(wù)A得到的余額是200,事務(wù)B得到的余額是300,如果事務(wù)B是后更新,那么就覆蓋了事務(wù)A的值。

在②處,事務(wù) A 和事務(wù)B都沒有提交的情況下,它們隨時(shí)都有可能發(fā)生回滾,如上圖這種情況事務(wù) A 發(fā)生了回滾,然后事務(wù)B再提交,那么對(duì)于事務(wù) B 看到的場(chǎng)景而言,就是自己明明更新了,結(jié)果值卻還是舊值,這就是 臟寫 。

1.2 臟讀

*臟讀(dirty read) ****, ***指的是讀到了其他事務(wù)未提交的數(shù)據(jù),未提交意味著可能會(huì)回滾,也就是可能最終不會(huì)持久化到數(shù)據(jù)庫(kù)中。其他事務(wù)讀到了不會(huì)持久化的數(shù)據(jù),這就是臟讀。

比如下圖,如果事務(wù)A在①處發(fā)生回滾,那么事務(wù)B在②處使用的Tom余額值200就是一個(gè)過期值,這種就是典型的 臟讀現(xiàn)象。

1.3 不可重復(fù)讀

*不可重復(fù)讀(non-repeatable read) *,指的是在同一事務(wù)內(nèi),相同數(shù)據(jù)在不同的時(shí)刻被讀到了不一樣的值,它和臟讀不一樣,臟讀是指讀取到了其他事務(wù)未提交的數(shù)據(jù),而不可重復(fù)讀表示讀到了其他事務(wù)修改并提交后的值。

比如有兩個(gè)事務(wù),事務(wù)A和事務(wù)B,事務(wù)A查詢Tom賬戶余額是100,事務(wù)B查詢Tom賬戶余額也是100。

接下來,事務(wù)A把Tom賬戶余額更新為200,并提交事務(wù)。

當(dāng)事務(wù)B繼續(xù)讀取Tom賬戶余額的時(shí)候,發(fā)現(xiàn)Tom賬戶余額是200了,和之前讀取到的不一致,對(duì)于事務(wù)B而言,這種一個(gè)事務(wù)內(nèi)多次讀取得到不一樣值的現(xiàn)象就稱為不可重復(fù)讀 現(xiàn)象。

1.4 幻讀

*幻讀(phantom read) *,主要是是針對(duì)數(shù)據(jù)插入(INSERT)和刪除(DELETE)操作來說的。

最經(jīng)典的是插入的情況。假如現(xiàn)在有兩個(gè)事務(wù),事務(wù)A和事務(wù)B。事務(wù)A對(duì)某些行的內(nèi)容作了更改,但是還未提交。

比如現(xiàn)在余額表中余額大于0的賬戶有2條,分別是小克和Tom,他們的富有程度都是貧窮:

mysql> select *from bank_balance where balance > 0;+----+-----------+-----------+--------+| id | user_name | balance | wealth |+----+-----------+-----------+--------+| 2 | 小克 | 300000000 | 0 || 3 | Tom | 100 | 0 |+----+-----------+-----------+--------+

然后,接到上級(jí)命令,要把所有賬戶余額大于0的用戶全部標(biāo)識(shí)為富有,啟動(dòng)事務(wù)A完成這項(xiàng)任務(wù),SQL如下:

update bank_balance set wealth = 1 where balance > 0;

SQL語句只是執(zhí)行了,但是未提交。

緊接著,事務(wù)B插入了一條余額大于0的記錄行(富有程度默認(rèn)為貧窮),并且在事務(wù)A提交之前先提交了,SQL如下:

INSERT INTO `bank_balance` (`id`, `user_name`, `balance`) VALUES ('4', 'Eric', '500');

在這之后,如果事務(wù)A再發(fā)起相同條件的查詢,會(huì)發(fā)現(xiàn)剛剛的更改對(duì)于某些數(shù)據(jù)未起作用(有些記錄未被標(biāo)識(shí)為富有),而且數(shù)據(jù)行比原來還多了!

這對(duì)于事務(wù)A而言,感覺出現(xiàn)了幻覺一樣,這就是幻讀現(xiàn)象。

1.5 區(qū)別

讀到這里,可能有些小伙伴就懵了,從臟讀到幻讀,感覺它們都一樣的呀?其實(shí),它們有實(shí)質(zhì)性的區(qū)別:

1、臟讀重在指一個(gè)事務(wù)讀到了其他事務(wù)未提交的數(shù)據(jù)。

2、不可重復(fù)讀主要在于一個(gè)事務(wù)中多次讀到同一條數(shù)據(jù),但前后讀到的結(jié)果不一樣,這是因?yàn)槠渌聞?wù)對(duì)數(shù)據(jù)進(jìn)行修改并提交導(dǎo)致。

3、幻讀則是因?yàn)楸黄渌聞?wù)插入或者刪除的數(shù)據(jù)影響,一個(gè)事務(wù)內(nèi)同樣條件的數(shù)據(jù)記錄變多或者變少了。

二、事務(wù)隔離級(jí)別

前面已經(jīng)講完并行事務(wù)可能出現(xiàn)的問題,具體表象就是臟寫,臟讀,不可重復(fù)讀,幻讀。

針對(duì)這些問題,SQL定了一套標(biāo)準(zhǔn),通過 隔離 來規(guī)避,且不同級(jí)別的隔離可以規(guī)避不同嚴(yán)重程度的事務(wù)問題,下面,我們一起看下SQL事務(wù) 隔離級(jí)別 都有哪些:

*讀未提交(READ UNCOMMITTED) *,指一個(gè)事務(wù)還沒提交,它做的修改就能被其他事務(wù)看到。

讀提 *交(READ COMMITTED) *,一個(gè)事務(wù)做的修改,只有提交之后,其他事務(wù)才能看到。

*可重復(fù)讀(REPEATABLE READ) *,在整個(gè)事務(wù)過程中看到的數(shù)據(jù),自始至終都是一致的。

*串行化(SERIALIZABLE) *,每個(gè)讀寫操作都會(huì)加鎖,多個(gè)事務(wù)要訪問同一條記錄時(shí),必須要進(jìn)行排隊(duì),優(yōu)先級(jí)低的事務(wù)必須等優(yōu)先級(jí)高的事務(wù)完成以后才能進(jìn)行。

從1到4,隔離級(jí)別依次變高,當(dāng)然,性能也依次變差。那么這些隔離級(jí)別究竟都能防止哪些問題呢?來看一個(gè)表格:

只有串行化的隔離級(jí)別解決了全部這 3 個(gè)問題,其他的 3 個(gè)隔離級(jí)別都有一定的缺陷。

但,MySQL InnoDB引擎默認(rèn)的隔離級(jí)別是可重復(fù)讀(RR) 。

為什么MySQL沒有使用串行化這個(gè)級(jí)別?是不是意味著我們?nèi)粘J褂肕ySQL會(huì)有可能存在幻讀的問題?

非也! 隔離級(jí)別越高代價(jià)也是越高的 ,且性能也越差。從性能上來說,當(dāng)然是隔離級(jí)別越低越好。

至于隔離級(jí)別是RR(可重復(fù)讀)下的MySQL怎么避免幻讀問題,InnoDB引擎有它自己的想法,以后單獨(dú)抽一講來說啦~

我們?cè)賮砜匆粡垐D,理解不同隔離級(jí)別下讀取到的數(shù)據(jù)是怎么樣的:

有兩個(gè)事務(wù),事務(wù)A和事務(wù)B,同時(shí)操作(查詢或者給Tom余額加100),事務(wù)B在事務(wù)A提交前更新了Tom的余額,并且事務(wù)B在事務(wù)A前提交。

讀未提交隔離級(jí)別 下,事務(wù) B 修改余額后,事務(wù) A 能夠馬上看見,即使事務(wù)B還未提交,所以事務(wù) A 中余額 R1 查詢的值是 200,余額 R2、R3 也是 200.

讀提交隔離級(jí)別 下,事務(wù) B 修改余額后,只有事務(wù)B提交后事務(wù)A才能看見,所以事務(wù)A中余額R1查詢?cè)谔峤磺埃榈闹凳?00,余額R2和余額R3都是在事務(wù)B提交后,查詢得到的值都是200。

可重復(fù)讀隔離級(jí)別 下,事務(wù)A在提交前自始至終查到的值都必須一樣,所以,余額R1、R2都是100,當(dāng)事務(wù)A提交后再查詢(其實(shí)是新事務(wù))就能查到新的值,所以R3是200。

串行化隔離級(jí)別 下,MySQL會(huì)給記錄行以及記錄行之間的'空行'加鎖,如果是A事務(wù)先獲得鎖,那么B事務(wù)必須等到A事務(wù)提交以后才能更新數(shù)據(jù)。

比如上圖,如果事務(wù)A查詢Tom余額的SQL條件是'where user_name = "Tom"', user_name有唯一索引,所以只會(huì)給Tom賬戶這一行數(shù)據(jù)加共享鎖 。

當(dāng)B事務(wù)要去更新Tom的賬戶余額時(shí),是獲取不到鎖的, 必須等待直至事務(wù)A完全提交 。

所以以上R1、R2查詢得到的值都是100(這個(gè)時(shí)候事務(wù)B在排隊(duì)等待),事務(wù)A提交以后, 事務(wù)B就可以更新值并提交了,R3是在事務(wù)B提交之后查詢,所以是200。

好啦,今天就先講到這里啦。

到此這篇關(guān)于一文帶你搞懂MySQL的事務(wù)隔離級(jí)別的文章就介紹到這了,更多相關(guān)MySQL事務(wù)隔離級(jí)別內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
91亚洲资源网| 尤物网精品视频| 日韩欧美一区二区视频| 精品二区久久| 国产一区二区三区电影在线观看| 中文字幕亚洲一区二区av在线| 欧美综合一区二区| 99r精品视频| 理论电影国产精品| 亚洲日本丝袜连裤袜办公室| 日韩欧美国产小视频| 久久久久久色| 亚洲一二区在线| 成人动漫在线一区| 美国毛片一区二区三区| 伊人色综合久久天天人手人婷| 久久久久久免费网| 制服丝袜成人动漫| 久久一区亚洲| 99精品欧美| 91网上在线视频| 激情欧美日韩一区二区| 亚洲福利视频三区| 一区二区中文字幕在线| 精品国产百合女同互慰| 91福利小视频| 国产三级精品在线不卡| 欧美国产精品| 国产精品69毛片高清亚洲| 亚洲第一主播视频| 成人免费在线观看入口| 久久久精品2019中文字幕之3| 5月丁香婷婷综合| 在线观看视频一区二区欧美日韩| 国产精品免费区二区三区观看| 欧美精品福利| 成人av电影免费在线播放| 久久国产精品露脸对白| 午夜精品久久久久久不卡8050| 亚洲猫色日本管| 国产精品美女久久久久久| 精品免费国产二区三区| 欧美一区日本一区韩国一区| 欧美曰成人黄网| 亚洲综合不卡| 亚洲精品一级| 黄色另类av| 欧美日韩高清在线一区| 91丝袜国产在线播放| 国产 欧美在线| 国内久久婷婷综合| 免费视频最近日韩| 午夜电影久久久| 一区二区在线观看视频| 中文字幕一区二| 中文字幕中文字幕一区| 国产精品拍天天在线| 国产蜜臀av在线一区二区三区| 久久久久久久电影| 久久综合九色综合97_久久久| 日韩欧美一二三| 欧美一卡二卡在线观看| 3d成人动漫网站| 精品视频一区三区九区| 色88888久久久久久影院野外| 久久国产主播精品| 国产一区二区三区免费不卡| 日韩视频在线一区二区三区| 亚洲毛片av| 中日韩在线视频| 国产精品一页| 午夜在线精品| 久久天堂国产精品| 日本乱人伦aⅴ精品| 欧美性欧美巨大黑白大战| 欧美最新大片在线看| 欧美色网一区二区| 欧美精品久久一区| 欧美一区二区三区影视| 日韩色视频在线观看| 日韩色在线观看| 久久亚洲精品小早川怜子| 精品国产污网站| 久久久一区二区三区| 久久久久久久久97黄色工厂| 欧美韩国一区二区| 亚洲欧美影音先锋| 亚洲综合图片区| 午夜激情综合网| 日本不卡免费在线视频| 免费精品视频在线| 国产在线精品一区二区不卡了 | 久久国产精品99精品国产| 日本不卡一区二区| 久久国产婷婷国产香蕉| 极品少妇xxxx精品少妇| 国产精品综合二区| 成人一区二区三区| 牛夜精品久久久久久久99黑人| 欧美日韩亚洲一区二区三区在线观看 | 欧美一区二区三区爱爱| 日韩久久免费av| 久久久一区二区| 中文字幕一区在线观看| 亚洲综合激情网| 免费人成在线不卡| 国产久卡久卡久卡久卡视频精品| 成人黄色在线视频| 午夜国产精品视频免费体验区| 亚洲高清在线| 亚洲欧美国产精品桃花| 在线免费观看日韩欧美| 91精品国产综合久久精品图片 | 免费不卡在线观看| 久久99最新地址| 成人久久18免费网站麻豆 | 欧美性一级生活| 91麻豆精品国产91| 日韩视频不卡中文| 久久精品无码一区二区三区| 最好看的中文字幕久久| 一区二区激情视频| 蜜臀av一区二区在线观看| 国产精品影视天天线| 91麻豆国产精品久久| 一本色道88久久加勒比精品| 色就色 综合激情| 欧美一区二区在线免费观看| 国产午夜亚洲精品不卡| 一区二区三区欧美日韩| 久久精品久久精品| 99精品热视频| 国产亚洲高清视频| 欧美性欧美巨大黑白大战| 精品国产91亚洲一区二区三区婷婷| 1000部国产精品成人观看| 亚洲va在线va天堂| 国产suv一区二区三区88区| 亚洲婷婷免费| 91福利在线看| 久久伊人中文字幕| 一区二区高清在线| 国产一二精品视频| 欧美久久一级| 久久精品国产第一区二区三区最新章节| 欧美在线观看视频一区二区| 精品久久国产老人久久综合| 亚洲品质自拍视频网站| 麻豆一区二区三| 成人a级免费电影| 国产精品免费区二区三区观看| 3atv在线一区二区三区| 亚洲欧美一区二区在线观看| 久久精品国产99久久6| 欧美1区2区视频| 久久久久国产精品一区二区| 精品国产一区二区三区四区四| 亚洲女女做受ⅹxx高潮| 久久精品国产亚洲aⅴ| 女同性一区二区三区人了人一| 性伦欧美刺激片在线观看| 日韩欧美区一区二| 一区二区三区高清| 国产精品一区二区免费不卡| 亚洲精选在线| 日韩一区二区三区观看| 亚洲欧美色一区| 国产精品系列在线观看| 日韩午夜电影| 欧美一级免费观看| 一区二区三区电影在线播| 成人黄色综合网站| 一本色道亚洲精品aⅴ| 欧美激情综合网| 美女视频黄久久| 欧美性事免费在线观看| 欧美日韩另类一区| 亚洲欧美日韩在线不卡| 国产乱人伦精品一区二区在线观看 | 99精品国产高清一区二区| 91精品在线免费| 亚洲欧美日韩一区二区三区在线观看| 国产一区二区精品久久| 日韩亚洲精品在线| 日韩欧美精品三级| 婷婷开心久久网| 国产精品99免费看| 欧美精品久久一区| 亚洲精品一二三四区| gogo大胆日本视频一区| 色一情一伦一子一伦一区| 国产欧美日韩一区二区三区在线观看| 免费视频一区二区| 亚洲激精日韩激精欧美精品| 日韩视频免费直播| 日本伊人午夜精品| 亚洲精品一级| 日韩一区二区三区av| 性做久久久久久免费观看| 欧美国产三区|