sql--數(shù)據(jù)庫(kù)事務(wù)

2018-10-08

數(shù)據(jù)庫(kù)事務(wù)

事務(wù)是一個(gè)操作序列,這些操作要么全執(zhí)行,要么全部不執(zhí)行,是一個(gè)不可分割的工作單元--ACID

原子性:是一個(gè)原子操作

一致性:在事務(wù)的開(kāi)始和完成,數(shù)據(jù)都必須保持一致?tīng)顟B(tài)。這意味著所有相關(guān)的數(shù)據(jù)規(guī)則都必須應(yīng)用于事務(wù)的修改,以保證數(shù)據(jù)的完整性。事務(wù)結(jié)束時(shí),所有的內(nèi)部數(shù)據(jù)結(jié)構(gòu)(如B數(shù)索引或雙向鏈表)也都必須是正確的

隔離性:保證事務(wù)在不受外部并發(fā)操作影響的“獨(dú)立”環(huán)境執(zhí)行。這意味著事務(wù)的處理過(guò)程中的中間狀態(tài)對(duì)外部是不可見(jiàn)的

持久性:事務(wù)完成之后,它對(duì)于數(shù)據(jù)的修改時(shí)永久性的,即使出現(xiàn)系統(tǒng)故障也能保持

并發(fā)一致性問(wèn)題

臟讀:事務(wù)t1更新了一行記錄內(nèi)容,但并沒(méi)有提交修改。事務(wù)t2讀取更新后的行,t1執(zhí)行回滾操作。t2讀取的就無(wú)效了(一個(gè)事務(wù)讀取了另一個(gè)事務(wù)未提交的數(shù)據(jù))

不可重復(fù)讀:事務(wù)t1讀取了一行記錄,緊接著t2修改了t1剛讀取的那一行數(shù)據(jù),然后t1再次讀取這行記錄,發(fā)現(xiàn)與剛才讀取的結(jié)果不同(一個(gè)事務(wù)讀到另一個(gè)事務(wù)已經(jīng)提交修改的數(shù)據(jù))

幻讀:事務(wù)t1讀取一個(gè)結(jié)果集,然后t2事務(wù)在t1結(jié)果集范圍內(nèi)插入一行記錄。然后t1再次對(duì)表進(jìn)行檢索,發(fā)現(xiàn)多了t2插入的數(shù)據(jù)(讀取到另一個(gè)事務(wù)新添加的數(shù)據(jù))

事務(wù)隔離級(jí)別

串行化(沒(méi)有并發(fā)一致性問(wèn)題):所有事務(wù)一個(gè)接一個(gè)的執(zhí)行,可以避免幻讀。對(duì)于基于鎖來(lái)實(shí)現(xiàn)并發(fā)數(shù)據(jù)庫(kù)來(lái)說(shuō),串行化要求在執(zhí)行范圍查詢的時(shí)候,需要獲取范圍鎖,如果不是基于鎖實(shí)現(xiàn)并發(fā)控制的數(shù)據(jù)庫(kù),則檢查到有違反串行操作的事務(wù)時(shí),需要回滾該事務(wù)

可重復(fù)讀(幻讀):所有被select獲取的數(shù)據(jù)都不能被修改,這樣就可以避免一個(gè)事務(wù)前后讀取不一致的情況,但是沒(méi)辦法控制幻讀。其他事務(wù)可以增加數(shù)據(jù)

讀已提交(幻讀、不可重復(fù)讀):被讀取的數(shù)據(jù)可以被其他事務(wù)修改,這樣可能導(dǎo)致不可重復(fù)讀

讀未提交(臟讀、不可重復(fù)讀、幻讀):允許其他事務(wù)看到?jīng)]有提交的數(shù)據(jù),會(huì)導(dǎo)致臟讀

數(shù)據(jù)庫(kù)事務(wù)實(shí)現(xiàn)原理

原子性:想要保證事務(wù)的原子性,就需要在異常發(fā)生時(shí),對(duì)已經(jīng)執(zhí)行的操作進(jìn)行回滾,mysql中通過(guò)回滾日志實(shí)現(xiàn)的,發(fā)生錯(cuò)誤或者需要回滾的事務(wù)能夠成功回滾

持久性:使用重做日志實(shí)現(xiàn)事務(wù)的持久性
在事務(wù)提交后,數(shù)據(jù)沒(méi)來(lái)得及寫(xiě)回磁盤(pán)就宕機(jī)時(shí),在下次重新啟動(dòng)后能夠成功恢復(fù)數(shù)據(jù)

一致性:不僅是數(shù)據(jù)庫(kù)對(duì)本身數(shù)據(jù)的完整性的要求,同時(shí)也對(duì)開(kāi)發(fā)者提出了要求,寫(xiě)出邏輯正確并且合理的事務(wù)

隔離性:三種最重要的并發(fā)控制器機(jī)制

鎖:共享鎖(讀鎖),互斥鎖(寫(xiě)鎖)
時(shí)間戳:經(jīng)常使用樂(lè)觀鎖
多版本和快照隔離:通過(guò)維護(hù)多個(gè)版本的數(shù)據(jù),數(shù)據(jù)庫(kù)可以允許事務(wù)在數(shù)據(jù)被其他事務(wù)更新時(shí)對(duì)舊版本數(shù)據(jù)進(jìn)行讀取

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容