MYSQL事務(wù)的4個(gè)級(jí)別

平常我們做業(yè)務(wù)的時(shí)候會(huì)經(jīng)常用到事務(wù),但是很少去關(guān)心事務(wù)的級(jí)別,實(shí)際上事務(wù)的級(jí)別的不同,對(duì)業(yè)務(wù)會(huì)產(chǎn)生不小的影響,比如有的級(jí)別的事務(wù)可能會(huì)產(chǎn)生臟讀,而有的級(jí)別可能會(huì)產(chǎn)生幻讀.

READ UNCOMMITTED(未提交讀)

在未提交讀這個(gè)事務(wù)級(jí)別中,一個(gè)事務(wù)可以讀取到另外一個(gè)事務(wù)未提交的數(shù)據(jù).
例如 A 事務(wù)更新了一個(gè)字段,但是未提交在 B 事務(wù)中,讀取id為999的記錄的name字段的時(shí)候,name的值為'aaa',可是 A 事務(wù)并沒(méi)有commit,所以name = 'aaa'有可能是會(huì)被回滾的,那么,A 事務(wù)這個(gè)操作就相當(dāng)于讀取了一個(gè)錯(cuò)誤的值.

A 事務(wù)這次讀取被稱為臟讀(Dirty Read)

READ COMMITTED(提交讀)

提交讀這個(gè)事務(wù)級(jí)別中,一個(gè)事務(wù)可以讀取到另外一個(gè)事務(wù)提交之后的數(shù)據(jù).

例如 A 事務(wù)讀取到了id為999的記錄的name字段為aaa ,然后 B 事務(wù)這個(gè)時(shí)候更新了這條記錄的name值,并且提交了,這個(gè)時(shí)候 A 事務(wù)再次讀取name的話,name的值就是bbb了,所以在一個(gè)事務(wù)中,對(duì)一個(gè)字段進(jìn)行多次讀取,可能得到的值不同.

REPEATABLE READ(可重復(fù)度)

可重復(fù)讀這個(gè)事務(wù)級(jí)別中,一個(gè)事務(wù)重復(fù)去讀的字段不會(huì)改變.

例如 A 事務(wù)讀取到了id為999的記錄的name值為aaa,然后 B 事務(wù)中把name改成了bbb,并且 B 事務(wù)提交了,A 事務(wù)再次去讀name的時(shí)候并不會(huì)讀取到bbb,所以 A 事務(wù)相當(dāng)于在一個(gè)獨(dú)立的世界,外界的任何改動(dòng)不會(huì)影響 A 事務(wù).

但是,可重復(fù)讀會(huì)導(dǎo)致幻讀出現(xiàn),什么是幻讀呢,舉個(gè)例子:
A 事務(wù)查詢一個(gè)表,表里只有一條記錄,id為1,但是這個(gè)時(shí)候 B 事務(wù)插入了一條數(shù)據(jù),id為2,A 事務(wù)因?yàn)椴恢烙衖d為2的數(shù)據(jù),所以這個(gè)時(shí)候A也插入了一條id為2的數(shù)據(jù),這個(gè)時(shí)候肯定會(huì)插入失敗.這種情況就是幻讀

MYSQL中的innoDB通過(guò)MVCC(多版本并發(fā)控制)解決了幻讀,另外MYSQL的默認(rèn)事務(wù)級(jí)別就是可重復(fù)讀

SERIALIZABLE(可串行化)

可串行化事務(wù)級(jí)別,把讀取的每一行數(shù)據(jù)都加了鎖

加鎖了的有點(diǎn)就是,避免了臟讀和幻讀,另外還避免了不可重復(fù)讀的可能性,但是因?yàn)榧渔i了,減少了很大的并發(fā)性,因?yàn)橥粫r(shí)刻,只有一個(gè)線程能夠獲取到鎖.還可能導(dǎo)致大量超時(shí)問(wèn)題.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末破婆,一起剝皮案震驚了整個(gè)濱河市筹麸,隨后出現(xiàn)的幾起案子设哗,更是在濱河造成了極大的恐慌适室,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件雏门,死亡現(xiàn)場(chǎng)離奇詭異除破,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)去团,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)穷蛹,“玉大人土陪,你說(shuō)我怎么就攤上這事‰妊” “怎么了鬼雀?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)蛙吏。 經(jīng)常有香客問(wèn)我源哩,道長(zhǎng),這世上最難降的妖魔是什么出刷? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任璧疗,我火速辦了婚禮,結(jié)果婚禮上馁龟,老公的妹妹穿的比我還像新娘崩侠。我一直安慰自己,他們只是感情好坷檩,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布却音。 她就那樣靜靜地躺著,像睡著了一般矢炼。 火紅的嫁衣襯著肌膚如雪系瓢。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,837評(píng)論 1 290
  • 那天句灌,我揣著相機(jī)與錄音夷陋,去河邊找鬼。 笑死胰锌,一個(gè)胖子當(dāng)著我的面吹牛骗绕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播资昧,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼酬土,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了格带?” 一聲冷哼從身側(cè)響起撤缴,我...
    開(kāi)封第一講書(shū)人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤刹枉,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后屈呕,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體微宝,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年凉袱,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了芥吟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片侦铜。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡专甩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出钉稍,到底是詐尸還是另有隱情涤躲,我是刑警寧澤,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布贡未,位于F島的核電站种樱,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏俊卤。R本人自食惡果不足惜嫩挤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望消恍。 院中可真熱鬧岂昭,春花似錦、人聲如沸狠怨。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)佣赖。三九已至恰矩,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間顾患,已是汗流浹背想诅。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工羊瘩, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人萎胰。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像豆胸,于是被迫代替她去往敵國(guó)和親奥洼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容