<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    初一七月

    你必須承認(rèn),我們生存的這個(gè)世界取決于自身的能力而非別人的保護(hù)(AW)
    隨筆 - 23, 文章 - 0, 評(píng)論 - 11, 引用 - 0
    數(shù)據(jù)加載中……

    數(shù)據(jù)庫(kù)并發(fā)問(wèn)題及事務(wù)隔離級(jí)別

        數(shù)據(jù)庫(kù)帶來(lái)的并發(fā)問(wèn)題主要包括:臟讀、不可重復(fù)讀與幻讀。

        臟讀,就是指當(dāng)一個(gè)事務(wù)正在訪問(wèn)數(shù)據(jù),并且對(duì)數(shù)據(jù)進(jìn)行了修改,而這種修改還沒(méi)有提交到數(shù)據(jù)庫(kù)中,這時(shí),另外一個(gè)事務(wù)也訪問(wèn)這個(gè)數(shù)據(jù),然后使用了這個(gè)數(shù)據(jù)。因?yàn)檫@個(gè)數(shù)據(jù)是還沒(méi)有提交的數(shù)據(jù),那么另外一個(gè)事務(wù)讀到的這個(gè)數(shù)據(jù)是臟數(shù)據(jù),依據(jù)臟數(shù)據(jù)所做的操作可能是不正確的。

        不可重復(fù)讀,是指在一個(gè)事務(wù)內(nèi),多次讀同一數(shù)據(jù)。在這個(gè)事務(wù)還沒(méi)有結(jié)束時(shí),另外一個(gè)事務(wù)也訪問(wèn)該同一數(shù)據(jù)。那么,在第一個(gè)事務(wù)中的兩次讀數(shù)據(jù)之間,由于第二個(gè)事務(wù)的修改,那么第一個(gè)事務(wù)兩次讀到的的數(shù)據(jù)可能是不一樣的。這樣就發(fā)生了在一個(gè)事務(wù)內(nèi)兩次讀到的數(shù)據(jù)是不一樣的,因此稱(chēng)為是不可重復(fù)讀。

        幻讀,是指當(dāng)事務(wù)不是獨(dú)立執(zhí)行時(shí)發(fā)生的一種現(xiàn)象,例如第一個(gè)事務(wù)對(duì)一個(gè)表中的數(shù)據(jù)進(jìn)行了修改,這種修改涉及到表中的全部數(shù)據(jù)行。同時(shí),第二個(gè)事務(wù)也修改這個(gè)表中的數(shù)據(jù),這種修改是向表中插入一行新數(shù)據(jù)。那么,以后就會(huì)發(fā)生操作第一個(gè)事務(wù)的用戶(hù)發(fā)現(xiàn)表中還有沒(méi)有修改的數(shù)據(jù)行,就好象發(fā)生了幻覺(jué)一樣。

        ANSI SQL中定義的4個(gè)隔離級(jí)實(shí)際上是用對(duì)鎖的操作來(lái)定義的:

        Read Uncommitted(未提交讀取,也叫臟讀): 讀數(shù)據(jù)時(shí)不加鎖。允許臟讀、不可重復(fù)讀、幻覺(jué)讀。
        Read Committed(提交讀取): 在讀數(shù)據(jù)之前加一個(gè)讀鎖,讀完之后釋放鎖。允許不可重復(fù)讀、幻覺(jué)讀。
        Repeatable Read(可重復(fù)讀取): 在讀數(shù)據(jù)之前加一個(gè)讀鎖,讀完之后不釋放鎖,直到事務(wù)rollback或者commit后才釋放鎖。允許幻覺(jué)讀。
        Serializable(串行化讀取): 在讀數(shù)據(jù)之前在讀取的條件上加鎖(稱(chēng)為條件鎖),讀完之后不釋放鎖,直到事務(wù)rollback或者commit后才釋放鎖。不允許臟讀、不可重復(fù)讀、幻讀。

        以下是對(duì)照表

       
    隔離級(jí)別 臟讀(Dirty Read) 不可重復(fù)讀(NonRepeatable Read) 幻讀(Phantom Read)
    讀未提交(Read uncommitted) 可能 可能 可能
    讀已提交(Read committed) 不可能 可能 可能
    可重復(fù)讀(Repeatable read) 不可能 不可能 可能
    可串行化(Serializable ) 不可能 不可能 不可能



    posted on 2010-12-13 23:30 初一七月 閱讀(739) 評(píng)論(1)  編輯  收藏 所屬分類(lèi): DB

    評(píng)論

    # re: 數(shù)據(jù)庫(kù)并發(fā)問(wèn)題及事務(wù)隔離級(jí)別  回復(fù)  更多評(píng)論   

    阿斯蒂芬
    2013-06-27 14:58 | 愛(ài)瘋
    主站蜘蛛池模板: 亚洲天堂电影在线观看| 曰韩无码AV片免费播放不卡 | 久久精品亚洲精品国产色婷 | 大妹子影视剧在线观看全集免费| 丝瓜app免费下载网址进入ios| 国产成人AV片无码免费| 中文字幕无码不卡免费视频 | 亚洲午夜福利精品无码| 亚洲AV午夜福利精品一区二区 | 亚洲毛片在线免费观看| 亚洲AV成人一区二区三区观看 | 美女内射无套日韩免费播放| 免费无码又爽又刺激高潮| 红杏亚洲影院一区二区三区| 亚洲成a人片在线观看播放| 视频一区在线免费观看| 无码人妻丰满熟妇区免费| 成年在线观看网站免费| 国产亚洲精品影视在线产品| 亚洲一卡二卡三卡| 97国免费在线视频| 日韩在线视频免费看| 久久精品国产96精品亚洲 | AV片在线观看免费| 亚洲国产精品成人久久| 久久免费视频观看| 男女啪啪永久免费观看网站| 亚洲大尺度无码无码专区| 在线观看亚洲视频| 99久久久国产精品免费无卡顿| 亚洲精品国产日韩无码AV永久免费网| 亚洲视频精品在线观看| 亚洲欧洲国产精品你懂的| 国产伦一区二区三区免费| 国产精品亚洲A∨天堂不卡| 亚洲人成网站色7799| 久久国产精品免费网站| 亚洲国产精品视频| 亚洲色成人网站WWW永久四虎 | 亚洲爆乳精品无码一区二区三区| 亚洲中文字幕无码爆乳app|