欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql事務(wù)并發(fā)臟讀+不可重復(fù)讀+幻讀詳解

 更新時間:2022年04月28日 11:27:31   作者:? 請叫我黃同學(xué)?  ?  
這篇文章主要介紹了Mysql事務(wù)并發(fā)臟讀+不可重復(fù)讀+幻讀詳解,文章基于Mysql事務(wù)的相關(guān)資料展開對主題的詳細介紹,具有一定的參考價值,需要的小伙伴可以參考一下

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更改默認(rèn)引擎為Innodb的步驟方法

    Mysql更改默認(rèn)引擎為Innodb的步驟方法

    mysql默認(rèn)是關(guān)閉InnoDB存儲引擎的使用的,而Mysql默認(rèn)引擎是MyISAM,而MyISAM并不支持事務(wù)處理,因為最近項目中的需要所以要更換引擎,通過查找網(wǎng)上的資料后解決了,現(xiàn)在將步驟方法分享給大家,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-12-12
  • MySQL基礎(chǔ)之MySQL 5.7 新增配置

    MySQL基礎(chǔ)之MySQL 5.7 新增配置

    mysql數(shù)據(jù)庫性能非常高,運行速度非常快,接下來通過本文給大家介紹MySQL 5.7 新增配置,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧
    2016-09-09
  • 高版本Mysql使用group?by分組報錯的解決方案

    高版本Mysql使用group?by分組報錯的解決方案

    GROUP?BY?語句用于結(jié)合合計函數(shù),根據(jù)一個或多個列對結(jié)果集進行分組,下面這篇文章主要給大家介紹了關(guān)于高版本Mysql使用group?by分組報錯的解決方案,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-03-03
  • mysql啟用skip-name-resolve模式時出現(xiàn)Warning的處理辦法

    mysql啟用skip-name-resolve模式時出現(xiàn)Warning的處理辦法

    在優(yōu)化MYSQL配置時,加入 skip-name-resolve ,在重新啟動MYSQL時檢查啟動日志,發(fā)現(xiàn)有警告信息
    2012-07-07
  • mysql left join快速轉(zhuǎn)inner join的過程

    mysql 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-06
  • 深入解析MySQL的窗口函數(shù)

    深入解析MySQL的窗口函數(shù)

    這篇文章主要介紹了深入解析MySQL的窗口函數(shù),窗口可以理解為記錄集合,窗口函數(shù)就是在滿足某種條件的記錄集合上執(zhí)行的特殊函數(shù),即:應(yīng)用在窗口內(nèi)的函數(shù),需要的朋友可以參考下
    2023-07-07
  • MySQL數(shù)據(jù)庫優(yōu)化經(jīng)驗詳談(服務(wù)器普通配置)

    MySQL數(shù)據(jù)庫優(yōu)化經(jīng)驗詳談(服務(wù)器普通配置)

    同時在線訪問量繼續(xù)增大 對于1G內(nèi)存的服務(wù)器明顯感覺到吃力嚴(yán)重時甚至每天都會死機 或者時不時的服務(wù)器卡一下 這個問題曾經(jīng)困擾了我半個多月MySQL使用是很具伸縮性的算法,因此你通常能用很少的內(nèi)存運行或給MySQL更多的被存以得到更好的性能。
    2011-03-03
  • mysql創(chuàng)建存儲過程及函數(shù)詳解

    mysql創(chuàng)建存儲過程及函數(shù)詳解

    大家好,本篇文章主要講的是mysql創(chuàng)建存儲過程及函數(shù)詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Windows環(huán)境下MySQL 8.0 的安裝、配置與卸載

    Windows環(huán)境下MySQL 8.0 的安裝、配置與卸載

    這篇文章主要介紹了Windows環(huán)境下MySQL 8.0 的安裝、配置與卸載步驟,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • mysql5.7.24 解壓版安裝步驟及遇到的問題小結(jié)

    mysql5.7.24 解壓版安裝步驟及遇到的問題小結(jié)

    這篇文章主要介紹了mysql5.7.24 解壓版安裝步驟以及遇到的問題 ,文中給大家提出了解決方案,需要的朋友可以參考下
    2018-11-11

最新評論