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