數(shù)據(jù)庫(kù)事務(wù)隔離的四個(gè)級(jí)別

數(shù)據(jù)庫(kù)隔離級(jí)別是在數(shù)據(jù)庫(kù)操作中,為了有效保證并發(fā)讀取數(shù)據(jù)的正確性提出的。

隔離級(jí)別越高碘菜,越能保證數(shù)據(jù)的完整性和一致性,但是對(duì)并發(fā)性能的影響也越大限寞。對(duì)于多數(shù)應(yīng)用程序忍啸,可以優(yōu)先考慮把數(shù)據(jù)庫(kù)系統(tǒng)的隔離級(jí)別設(shè)為Read Committed。它能夠避免臟讀取履植,而且具有較好的并發(fā)性能计雌。盡管它會(huì)導(dǎo)致不可重復(fù)讀、幻讀和第二類丟失更新這些并發(fā)問題玫霎,在可能出現(xiàn)這類問題的個(gè)別場(chǎng)合凿滤,可以由應(yīng)用程序采用悲觀鎖或樂觀鎖來控制。

數(shù)據(jù)庫(kù)的幾種隔離級(jí)別:

READ UNCOMMITTED(讀未提交數(shù)據(jù)): 允許事務(wù)讀取未被其他事務(wù)提交的變更數(shù)據(jù)庶近,會(huì)出現(xiàn)臟讀翁脆、不可重復(fù)讀和幻讀問題。

READ COMMITTED(讀已提交數(shù)據(jù)): 只允許事務(wù)讀取已經(jīng)被其他事務(wù)提交的變更數(shù)據(jù)鼻种,可避免臟讀反番,仍會(huì)出現(xiàn)不可重復(fù)讀和幻讀問題。

REPEATABLE READ(可重復(fù)讀): 確保事務(wù)可以多次從一個(gè)字段中讀取相同的值叉钥,在此事務(wù)持續(xù)期間罢缸,禁止其他事務(wù)對(duì)此字段的更新,可以避免臟讀和不可重復(fù)讀投队,仍會(huì)出現(xiàn)幻讀問題枫疆。

SERIALIZABLE(序列化): 確保事務(wù)可以從一個(gè)表中讀取相同的行,在這個(gè)事務(wù)持續(xù)期間敷鸦,禁止其他事務(wù)對(duì)該表執(zhí)行插入息楔、更新和刪除操作,可避免所有并發(fā)問題轧膘,但性能非常低钞螟。

Oracle支持兩種事務(wù)隔離級(jí)別:
READ COMMITTED(默認(rèn)事務(wù)隔離級(jí)別),SERIALIZABLE
MySQL支持四種事務(wù)隔離級(jí)別谎碍,其中REPEATABLE READ為默認(rèn)事務(wù)隔離級(jí)別鳞滨。

通過上面可以知道多事務(wù)同時(shí)運(yùn)行,如果不采用以上四種隔離機(jī)制蟆淀,可能會(huì)產(chǎn)生多個(gè)并發(fā)問題拯啦,其中包括臟讀澡匪、不可重復(fù)讀和幻讀,下面就解釋下這幾種并發(fā)問題:

存在兩個(gè)事務(wù)(T1褒链,T2)同時(shí)運(yùn)行

臟讀: T1讀取了已經(jīng)被T2修改但還未提交的字段唁情,由于某種原因,T2事務(wù)回滾甫匹,則T1讀取的內(nèi)容是臨時(shí)且無效的甸鸟。
不可重復(fù)讀:T1讀取一個(gè)字段,之后T2更新了該字段兵迅,T1在此讀取該字段值發(fā)生了變化抢韭。在可重復(fù)讀中,該sql第一次讀取到數(shù)據(jù)后恍箭,就將這些數(shù)據(jù)加鎖(悲觀鎖)刻恭,其它事務(wù)無法修改這些數(shù)據(jù),就可以實(shí)現(xiàn)可重復(fù)讀了扯夭。但這種方法卻無法鎖住insert的數(shù)據(jù)鳍贾,所以當(dāng)事務(wù)A先前讀取了數(shù)據(jù),或者修改了全部數(shù)據(jù)交洗,事務(wù)B還是可以insert數(shù)據(jù)提交骑科,這時(shí)事務(wù)A就會(huì)發(fā)現(xiàn)莫名其妙多了一條之前沒有的數(shù)據(jù),這就是幻讀藕筋,不能通過行鎖來避免纵散。
幻讀: T1從一個(gè)表中讀取了一個(gè)字段,然后T2在該表中插入了一些新的行隐圾,之后T1在此讀取該表會(huì)多出幾行。讀用讀鎖掰茶,寫用寫鎖暇藏,讀鎖和寫鎖互斥,這么做可以有效的避免幻讀濒蒋、不可重復(fù)讀盐碱、臟讀等問題,但會(huì)極大的降低數(shù)據(jù)庫(kù)的并發(fā)能力沪伙。

數(shù)據(jù)庫(kù)事務(wù)的特性:原子性瓮顽、一致性、隔離性围橡、持久性

原子性: 事務(wù)的原子性指的是暖混,事務(wù)中包含的程序作為數(shù)據(jù)庫(kù)的邏輯工作單位,它所做的對(duì)數(shù)據(jù)修改操作要么全部執(zhí)行翁授,要么完全不執(zhí)行拣播,這種特性稱為原子性晾咪。(簡(jiǎn)單地說就是,幾個(gè)對(duì)于數(shù)據(jù)庫(kù)的操作要么全執(zhí)行贮配,要么全不執(zhí)行谍倦,即同時(shí)成功起作用或同時(shí)失敗沒影響)

一致性:事務(wù)一致性值得是在一個(gè)事務(wù)執(zhí)行之前和執(zhí)行之后數(shù)據(jù)庫(kù)都必須處于一致性狀態(tài)(中途是否一致不用管),這種特性稱為一致性泪勒。(如果數(shù)據(jù)庫(kù)的狀態(tài)滿足所有的完整性約束昼蛀,就說該數(shù)據(jù)庫(kù)是一致的。一致性處理數(shù)據(jù)庫(kù)中對(duì)所有語(yǔ)義的保護(hù)圆存。如:客戶K1要向客戶K2轉(zhuǎn)賬叼旋,K1賬戶減少的金額就是K2賬戶增加的金額,在轉(zhuǎn)賬之前K1和K2賬戶的金額之和與轉(zhuǎn)賬之后K1和K2賬戶的金額之和是一樣的辽剧,在轉(zhuǎn)賬期間可能不滿足這種一致性送淆,但事務(wù)前后是數(shù)據(jù)庫(kù)數(shù)據(jù)是一致的)

隔離性: 隔離性指的是并發(fā)的事務(wù)是相互隔離的。(一個(gè)事務(wù)內(nèi)部的操作及正在操作的數(shù)據(jù)必須封裝起來怕轿,不被其它企圖進(jìn)行修改的事務(wù)看到)

持久性: 持久性指當(dāng)系統(tǒng)或介質(zhì)發(fā)生故障時(shí)偷崩,確保已提交的更新不能丟失。(一個(gè)事務(wù)提交撞羽,DBMS保證它對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的改變應(yīng)該是永久性的阐斜,可以經(jīng)受任何系統(tǒng)故障,持久性通過數(shù)據(jù)庫(kù)備份和恢復(fù)來保證)





————————————————
版權(quán)聲明:本文為CSDN博主「燦爛小八戒」的原創(chuàng)文章诀紊,遵循CC 4.0 BY-SA版權(quán)協(xié)議谒出,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/A1174316452/article/details/109442748

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末邻奠,一起剝皮案震驚了整個(gè)濱河市笤喳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌碌宴,老刑警劉巖杀狡,帶你破解...
    沈念sama閱讀 221,198評(píng)論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異贰镣,居然都是意外死亡呜象,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門碑隆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來恭陡,“玉大人,你說我怎么就攤上這事上煤⌒萃妫” “怎么了?”我有些...
    開封第一講書人閱讀 167,643評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)哥捕。 經(jīng)常有香客問我牧抽,道長(zhǎng),這世上最難降的妖魔是什么遥赚? 我笑而不...
    開封第一講書人閱讀 59,495評(píng)論 1 296
  • 正文 為了忘掉前任扬舒,我火速辦了婚禮,結(jié)果婚禮上凫佛,老公的妹妹穿的比我還像新娘讲坎。我一直安慰自己,他們只是感情好愧薛,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,502評(píng)論 6 397
  • 文/花漫 我一把揭開白布晨炕。 她就那樣靜靜地躺著,像睡著了一般毫炉。 火紅的嫁衣襯著肌膚如雪瓮栗。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,156評(píng)論 1 308
  • 那天瞄勾,我揣著相機(jī)與錄音费奸,去河邊找鬼。 笑死进陡,一個(gè)胖子當(dāng)著我的面吹牛愿阐,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播趾疚,決...
    沈念sama閱讀 40,743評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼缨历,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了糙麦?” 一聲冷哼從身側(cè)響起辛孵,我...
    開封第一講書人閱讀 39,659評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎赡磅,沒想到半個(gè)月后觉吭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,200評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡仆邓,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,282評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了伴鳖。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片节值。...
    茶點(diǎn)故事閱讀 40,424評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖榜聂,靈堂內(nèi)的尸體忽然破棺而出搞疗,到底是詐尸還是另有隱情,我是刑警寧澤须肆,帶...
    沈念sama閱讀 36,107評(píng)論 5 349
  • 正文 年R本政府宣布匿乃,位于F島的核電站桩皿,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏幢炸。R本人自食惡果不足惜泄隔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,789評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宛徊。 院中可真熱鬧佛嬉,春花似錦、人聲如沸闸天。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)苞氮。三九已至湾揽,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間笼吟,已是汗流浹背库物。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評(píng)論 1 271
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留赞厕,地道東北人艳狐。 一個(gè)月前我還...
    沈念sama閱讀 48,798評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像皿桑,于是被迫代替她去往敵國(guó)和親毫目。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,435評(píng)論 2 359

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