數(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