臟讀就是指讀到還沒完全弄好的數(shù)據(jù)。避免臟讀的辦法就是采取事務(wù),使得他用戶正在更新時鎖定數(shù)據(jù)庫,阻止你讀取,直至全部完成才讓你讀取。
為平湖等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及平湖網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、平湖網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
臟讀就是指當(dāng)一個事務(wù)正在訪問數(shù)據(jù),并且對數(shù)據(jù)進(jìn)行了修改,而這種修改還沒有提交到數(shù)據(jù)庫中,這時,另外一個事務(wù)也訪問這個數(shù)據(jù),然后使用了這個數(shù)據(jù)。因為這個數(shù)據(jù)是還沒有提交的數(shù)據(jù),那么另外一個事務(wù)讀到的這個數(shù)據(jù)是臟數(shù)據(jù),依據(jù)臟數(shù)據(jù)所做的操作可能是不正確的。
數(shù)據(jù)庫(Database)是按照數(shù)據(jù)結(jié)構(gòu)來組織、存儲和管理數(shù)據(jù)的倉庫,它產(chǎn)生于距今六十多年前,隨著信息技術(shù)和市場的發(fā)展,特別是二十世紀(jì)九十年代以后,數(shù)據(jù)管理不再僅僅是存儲和管理數(shù)據(jù),而轉(zhuǎn)變成用戶所需要的各種數(shù)據(jù)管理的方式。數(shù)據(jù)庫有很多種類型。
數(shù)據(jù)庫是一個單位或是一個應(yīng)用領(lǐng)域的通用數(shù)據(jù)處理系統(tǒng),它存儲的是屬于企業(yè)和事業(yè)部門、團(tuán)體和個人的有關(guān)數(shù)據(jù)的集合。數(shù)據(jù)庫中的數(shù)據(jù)是從全局觀點出發(fā)建立的,按一定的數(shù)據(jù)模型進(jìn)行組織、描述和存儲。其結(jié)構(gòu)基于數(shù)據(jù)間的自然聯(lián)系,從而可提供一切必要的存取路徑,且數(shù)據(jù)不再針對某一應(yīng)用,而是面向全組織,具有整體的結(jié)構(gòu)化特征。
mysql事務(wù)隔離級別如下:
1.讀取未提交(READ-UNCOMMITTED):最低的隔離級別,允許讀取尚未提交的數(shù)據(jù)變更,可能造成臟讀、不可重復(fù)讀、幻讀。
2.讀取已提交(READ-COMMITTED):允許讀取并發(fā)事務(wù)已經(jīng)提交的數(shù)據(jù),可以避免臟讀,但是可能造成不可重復(fù)、幻讀。
3.可重復(fù)讀(REPEATABLE-READ):對同一字段多次讀取的結(jié)果都是一致的,除非本身事務(wù)修改,可以避免臟讀和不可重復(fù)讀,但是可能造成幻讀。
4.可串行化(SERIALIZABLE):最高的隔離級別,完全服從ACID的隔離級別,所以的事務(wù)依次執(zhí)行,可以避免臟讀、不可重復(fù)讀、幻讀。
事務(wù)的特性:
1.原子性:事務(wù)最小的執(zhí)行單位,不允許分割。事務(wù)的原子性確保動作要么全部執(zhí)行,要么全部不執(zhí)行。
2.一致性:執(zhí)行事務(wù)的前后,數(shù)據(jù)保持一致。例如轉(zhuǎn)賬的業(yè)務(wù)中,無論事務(wù)是否成功,轉(zhuǎn)賬者和收款人的總額應(yīng)該是不變的。
3.隔離性:并發(fā)訪問數(shù)據(jù)庫時,一個用戶的事務(wù)不應(yīng)該被其他事務(wù)所影響,各并發(fā)事務(wù)之間數(shù)據(jù)庫是獨立的。
4.持久性:一個事務(wù)被提交后,它對數(shù)據(jù)庫中數(shù)據(jù)的改變是持久的,即使數(shù)據(jù)庫發(fā)生故障也不應(yīng)該對其有影響。
3). 幻讀 :
是指當(dāng)事務(wù)不是獨立執(zhí)行時發(fā)生的一種現(xiàn)象,例如第一個事務(wù)對一個表中的數(shù)據(jù)進(jìn)行了修改,這種修改涉及到表中的全部數(shù)據(jù)行。同時,第二個事務(wù)也修改這個表中的數(shù)據(jù),這種修改是向表中插入一行新數(shù)據(jù)。那么,以后就會發(fā)生操作第一個事務(wù)的用戶發(fā)現(xiàn)表中還有沒有修改的數(shù)據(jù)行,就好象發(fā)生了幻覺一樣。例如,一個編輯人員更改作者提交的文檔,但當(dāng)生產(chǎn)部門將其更改內(nèi)容合并到該文檔的主復(fù)本時,發(fā)現(xiàn)作者已將未編輯的新材料添加到該文檔中。如果在編輯人員和生產(chǎn)部門完成對原始文檔的處理之前,任何人都不能將新材料添加到文檔中,則可以避免該問題。
眾所周知,Mysql在InnoDB下有四種隔離級別:
未提交讀(Read Uncommitted)
提交后讀(Read Committed)
可重復(fù)讀(Repeatable Read)
串行化(Serializable)
其中可重復(fù)讀(RR)可以避免臟讀( a事務(wù)讀到b事務(wù)回滾前的數(shù)據(jù))以及可不重復(fù)讀( a事務(wù)在b事務(wù)修改提交的前后,兩次分別讀到的數(shù)據(jù)不一致)。但是對于幻讀(a事務(wù)在b事務(wù)insert提交前后,兩次分別讀到的數(shù)據(jù)不一致),卻存在爭議。
下面我們來做一個試驗:
對于下面這張簡單的數(shù)據(jù)表
id? ? ? ? num
1 ????????11
2 ????????22
3 ????????33
我們開啟a、b兩個事務(wù)
a事務(wù)? ? ? ? ? ? ????b事務(wù)
begin? ? ? ? ? ? ????begin
select * from tb? ? ----
----? ? ? ? ? ? ? ? ? ? insert into tb (id,num)values(4,44)
----? ? ? ? ? ? ? ? ? ? commit
select * from tb? ? ----
commit
試驗結(jié)果:a事務(wù)的兩次select查詢到的結(jié)果相同,在后一次查詢中沒有返回新插入id=4的那條記錄。
據(jù)此,很多人判斷說RR隔離級別下“不存在”幻讀。
但果真如此嗎?----
出現(xiàn)上面的試驗結(jié)果,是因為在RR隔離級別事務(wù)下,Mysql會對前一次select的結(jié)果快照。所以第二次select其實是快照讀(這也正是RR隔離級別下能夠避免不可重復(fù)讀的策略)。
如果我們把試驗條件稍作修改,同樣開啟a、b兩個事務(wù):
a事務(wù)? ? ? ? ? ? ????b事務(wù)
begin? ? ? ? ? ? ????begin
select * from tb? ? ----
----? ? ? ? ? ? ? ? ? ? insert into tb (id,num)values(5,55)
----? ? ? ? ? ? ? ? ? ? commit
update tb set num=num+1? ? ----? ? ? ? #此處a事務(wù)做一次修改操作
select * from tb? ? ----
commit
試驗結(jié)果:在a事務(wù)的第二次select中出現(xiàn)了b事務(wù)新插入的id=5的記錄。
由于做了update操作,之前的快照失效了,所以說RR隔離級別下的快照策略并沒能真正避免幻讀。
ps. 假如給第二次的select查詢上鎖(無論是共享鎖還是排它鎖),也會得到同樣的結(jié)果,都會令快照失效。
幻讀是指:在一個事務(wù)中,讀取到了其他已經(jīng)提交的事務(wù)插入的數(shù)據(jù)行。
MySQL在解決臟讀、不可重復(fù)的讀時候,使用了MVCC一致性視圖,同時配合行鎖來解決。
至于幻讀的解決方式,MySQL引入了臨鍵鎖,通過間隙鎖可以避免在兩個行之間插入數(shù)據(jù),從而避免了一個事務(wù)在讀取的過程中,讀取到其他事務(wù)插入的數(shù)據(jù)行。
學(xué)習(xí)msyql隔離級別,事務(wù),行排它鎖,行共享鎖,樂觀鎖,悲觀鎖即可