Mysql事務(wù)并發(fā)臟讀+不可重復(fù)讀+幻讀詳解
Mysql的事務(wù)隔離級(jí)別
Mysql有四種事務(wù)隔離級(jí)別,這四種隔離級(jí)別代表當(dāng)存在多個(gè)事務(wù)并發(fā)沖突時(shí),可能出現(xiàn)的臟讀、不可重復(fù)讀、幻讀的問題。
臟讀
大家看一下,我們有兩個(gè)事務(wù),一個(gè)是 Transaction A,一個(gè)是 Transaction B,在第一個(gè)事務(wù)里面,它首先通過一個(gè) where id=1 的條件查詢一條數(shù)據(jù),返回 name=Ada,age=16 的這條數(shù)據(jù)。然后第二個(gè)事務(wù)呢,它同樣地是去操作 id=1 的這行數(shù)據(jù),它通過一個(gè) update 的語(yǔ)句,把這行 id=1 的數(shù)據(jù)的 age 改成了 18,但是大家注意,它沒有提交。這個(gè)時(shí)候,在第一個(gè)事務(wù)里面,它再次去執(zhí)行相同的查詢操作,發(fā)現(xiàn)數(shù)據(jù)發(fā)生了變化,獲取到的數(shù)據(jù) age 變成了 18。那么,這種在一個(gè)事務(wù)里面,由于其他的時(shí)候修改了數(shù)據(jù)并且沒有提交,而導(dǎo)致了前后兩次讀取數(shù)據(jù)不一致的情況,這種事務(wù)并發(fā)的問題,我們把它定義成臟讀。
不可重復(fù)讀
同樣是兩個(gè)事務(wù),第一個(gè)事務(wù)通過 id=1 查詢到了一條數(shù)據(jù)。然后在第二個(gè)事務(wù)里面執(zhí)行了一個(gè) update 操作,這里大家注意一下,執(zhí)行了 update 以后它通過一個(gè) commit提交了修改。然后第一個(gè)事務(wù)讀取到了其他事務(wù)已提交的數(shù)據(jù)導(dǎo)致前后兩次讀取數(shù)據(jù)不一致的情況,就像這里,age 到底是等于 16 還是 18,那么這種事務(wù)并發(fā)帶來的問題,我們把它叫做不可重復(fù)讀。
幻讀
在第一個(gè)事務(wù)里面我們執(zhí)行了一個(gè)范圍查詢,這個(gè)時(shí)候滿足條件的數(shù)據(jù)只有一條。在第二個(gè)事務(wù)里面,它插入了一行數(shù)據(jù),并且提交了。重點(diǎn):插入了一行數(shù)據(jù)。在第一個(gè)事務(wù)里面再去查詢的時(shí)候,它發(fā)現(xiàn)多了一行數(shù)據(jù)。
一個(gè)事務(wù)前后兩次讀取數(shù)據(jù)數(shù)據(jù)不一致,是由于其他事務(wù)插入數(shù)據(jù)造成的,這種情況我們把它叫做幻讀。
總結(jié)
不可重復(fù)讀是修改或者刪除,幻讀是插入。 無論是臟讀,還是不可重復(fù)讀,還是幻讀,它們都是數(shù)據(jù)庫(kù)的讀一致性的問題,都是在一個(gè)事務(wù)里面前后兩次讀取出現(xiàn)了不一致的情況。
到此這篇關(guān)于Mysql事務(wù)并發(fā)臟讀+不可重復(fù)讀+幻讀詳解的文章就介紹到這了,更多相關(guān)Mysql事務(wù)并發(fā)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
高版本Mysql使用group?by分組報(bào)錯(cuò)的解決方案
GROUP?BY?語(yǔ)句用于結(jié)合合計(jì)函數(shù),根據(jù)一個(gè)或多個(gè)列對(duì)結(jié)果集進(jìn)行分組,下面這篇文章主要給大家介紹了關(guān)于高版本Mysql使用group?by分組報(bào)錯(cuò)的解決方案,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03mysql啟用skip-name-resolve模式時(shí)出現(xiàn)Warning的處理辦法
在優(yōu)化MYSQL配置時(shí),加入 skip-name-resolve ,在重新啟動(dòng)MYSQL時(shí)檢查啟動(dòng)日志,發(fā)現(xiàn)有警告信息2012-07-07mysql left join快速轉(zhuǎn)inner join的過程
inner join內(nèi)連接,顯示兩個(gè)表中有聯(lián)系的所有數(shù)據(jù)而left join,左鏈接,以左表為參照,顯示所有數(shù)據(jù),右表中沒有則以null顯示,本文重點(diǎn)給大家講解mysql left join快速轉(zhuǎn)inner join的過程,需要的朋友參考下吧2021-06-06MySQL數(shù)據(jù)庫(kù)優(yōu)化經(jīng)驗(yàn)詳談(服務(wù)器普通配置)
同時(shí)在線訪問量繼續(xù)增大 對(duì)于1G內(nèi)存的服務(wù)器明顯感覺到吃力嚴(yán)重時(shí)甚至每天都會(huì)死機(jī) 或者時(shí)不時(shí)的服務(wù)器卡一下 這個(gè)問題曾經(jīng)困擾了我半個(gè)多月MySQL使用是很具伸縮性的算法,因此你通常能用很少的內(nèi)存運(yùn)行或給MySQL更多的被存以得到更好的性能。2011-03-03mysql創(chuàng)建存儲(chǔ)過程及函數(shù)詳解
大家好,本篇文章主要講的是mysql創(chuàng)建存儲(chǔ)過程及函數(shù)詳解,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12Windows環(huán)境下MySQL 8.0 的安裝、配置與卸載
這篇文章主要介紹了Windows環(huán)境下MySQL 8.0 的安裝、配置與卸載步驟,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09mysql5.7.24 解壓版安裝步驟及遇到的問題小結(jié)
這篇文章主要介紹了mysql5.7.24 解壓版安裝步驟以及遇到的問題 ,文中給大家提出了解決方案,需要的朋友可以參考下2018-11-11