久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

DB2數(shù)據(jù)庫(kù)的隔離級(jí)解讀與試驗(yàn)

瀏覽:29日期:2023-11-10 09:01:42

基本信息

摘要:在DB2中,共有四種隔離級(jí):RS,RR,CS,UR.以下對(duì)四種隔離級(jí)進(jìn)行一些描述,同時(shí)附上個(gè)人做試驗(yàn)的結(jié)果。隔離級(jí)是影響加鎖策略的重要環(huán)節(jié),它直接影響加鎖的范圍及鎖的持續(xù)時(shí)間。兩個(gè)應(yīng)用程序即使執(zhí)行的相同的操作,也可能由于選擇的隔離級(jí)的不同而造成加鎖的結(jié)果不同。

隔離級(jí)解讀和試驗(yàn)

隔離級(jí)是影響加鎖策略的重要環(huán)節(jié),它直接影響加鎖的范圍及鎖的持續(xù)時(shí)間。兩個(gè)應(yīng)用程序即使執(zhí)行的相同的操作,也可能由于選擇的隔離級(jí)的不同而造成加鎖的結(jié)果不同。在DB2中,共有四種隔離級(jí):RS,RR,CS,UR.以下對(duì)四種隔離級(jí)進(jìn)行一些描述,同時(shí)附上個(gè)人做試驗(yàn)的結(jié)果。

讀可靠性(RS-Read Stability)如果使用這種隔離級(jí),在一個(gè)事務(wù)中所有被讀取過(guò)的行上都會(huì)被加上NS鎖,直到該事務(wù)被提交或回滾,行上的鎖才會(huì)被釋放。這樣可以保證在一個(gè)事務(wù)中即使多次讀取同一行,得到的值不會(huì)改變。

但是,如果使用這種隔離級(jí),在一個(gè)事務(wù)中,如果使用同樣的搜索標(biāo)準(zhǔn)重新打開(kāi)已被處理過(guò)的游標(biāo),則結(jié)果集可能改變。(可能會(huì)增加某些行,這些行被稱為幻影行(Phantom))。這是因?yàn)镽S隔離級(jí)不能阻止通過(guò)插入或更新操作在結(jié)果集中加入新行。

個(gè)人筆記:

 根據(jù)實(shí)際測(cè)試情況,RS模式下:查詢完畢以后,滿足條件的結(jié)果集中的記錄被鎖定,不滿足條件的不被鎖定。

 可以對(duì)不滿足條件的記錄更新,也可以插入新的記錄。其他人可以查詢滿足已經(jīng)鎖定的記錄,但不可以更新。

重復(fù)讀(RR-Repeat Read)如果使用這種隔離級(jí),在一個(gè)事務(wù)中所有被讀取過(guò)的行上都會(huì)被加上S鎖,知道該事務(wù)被提交或回滾,行上的鎖才會(huì)被釋放。這樣可以保證在一個(gè)事務(wù)中即使多次讀取同一行,得到的值不會(huì)改變。

另外,在同一事務(wù)中如果以同樣的搜索標(biāo)準(zhǔn)重新打開(kāi)已被處理過(guò)的游標(biāo),得到的結(jié)果集不會(huì)改變。重復(fù)讀相對(duì)于讀可靠性而言,加鎖的范圍更大。

對(duì)于讀可靠性,應(yīng)用程序只對(duì)符合要求的所有行加鎖,而對(duì)于重復(fù)讀,應(yīng)用程序?qū)?duì)所有被掃描過(guò)的行都加鎖。例如,如果一個(gè)應(yīng)用程序?qū)σ粋€(gè)表中的 10000行數(shù)據(jù)進(jìn)行掃描,最終找到了100條符合搜索條件的結(jié)果行。如果該應(yīng)用程序使用的是讀可靠性隔離級(jí),應(yīng)用程序?qū)⒅粚?duì)這符合條件的100行加鎖;如果該應(yīng)用程序使用的是重復(fù)讀隔離級(jí),應(yīng)用程序?qū)?duì)被掃描過(guò)的10000行都加鎖。

個(gè)人筆記

 根據(jù)實(shí)際測(cè)試情況,RR模式下:查詢完畢以后,不可以對(duì)不滿足條件的進(jìn)行更新,也不可以插入新記錄。可能原因是:如果允許別人更新記錄或者插入新記錄的話,則可能造成原來(lái)結(jié)果集的破壞,重新讀的時(shí)候和以前不同。

 select for update with rr/rs 是可以用來(lái)實(shí)現(xiàn)記錄鎖。是一種特殊情況。即便是RR,仍然可以對(duì)其他記錄操作。

游標(biāo)可靠性(CS-Cursor Stability)如果使用這種隔離級(jí),在一個(gè)事務(wù)中,結(jié)果集中只有正在被讀取的那一行(游標(biāo)指向的行)將被加上NS鎖,其他未被處理的行上不被加鎖。這種隔離級(jí)只能保證正在被處理的行的值不會(huì)被其他并發(fā)的程序所改變。該隔離級(jí)是DB2缺省的隔離級(jí)。

個(gè)人筆記

僅僅在游標(biāo)在該行的時(shí)候鎖定,這是一種非常弱的隔離狀態(tài)。

未提交讀(UR-Uncommitted Read)如果使用這種隔離級(jí),對(duì)于只讀操作,不加行鎖。典型的只讀操作包括:

 SELECT語(yǔ)句的結(jié)果集只讀(比如語(yǔ)句中包括ORDER BY子句);

定義游標(biāo)是指明起為FOR FETCH ONLY。

該隔離級(jí)可以改善應(yīng)用程序的性能,同時(shí)可以最大程度的允許并發(fā)。但是,應(yīng)用程序的數(shù)據(jù)完整性將受到威脅。如果需要讀取未提交的數(shù)據(jù),該隔離級(jí)是唯一選擇。

個(gè)人筆記

讀的時(shí)候完全不受限制,對(duì)于同一行記錄的完整性也無(wú)法保證。

總結(jié)

以上我們所提的隔離級(jí)的加鎖范圍和持續(xù)時(shí)間都是針對(duì)于讀操作而言的。

對(duì)于更改操作,被修改的行上會(huì)被加上X鎖,不論使用何種隔離級(jí),X鎖直到提交或回滾之后才會(huì)被釋放。

標(biāo)簽: DB2 數(shù)據(jù)庫(kù)
主站蜘蛛池模板: 午夜激情视频在线观看 | 一区二区视频 | 国产精品成人免费视频 | 在线看av网址 | 成年人在线观看 | 伊人小视频 | 国产成人免费视频 | 久草视| 亚洲成人网一区 | 国偷自产av一区二区三区 | 欧美高清一区 | 亚洲精品久久 | 成年人在线观看视频 | 亚洲一区| www国产精品 | 久久久精品欧美一区二区免费 | 久久视频一区 | 成人精品一区 | 日韩欧美精品一区 | 日韩精品在线观看免费 | 国产精品美女久久久久久久网站 | 欧美日韩精品综合 | 国产精品1区2区3区 国产在线观看一区 | 免费a视频 | 亚洲一区精品在线 | 欧美精品综合 | 午夜视频网站 | 91在线资源 | 久久免费精品 | 密色视频 | 成人二区 | 欧美日韩在线免费 | 成人毛片视频网站 | 亚洲一区成人在线 | 午夜亚洲一区 | 美女久久久 | 一区二区日韩 | 97久久精品 | 久久精品免费观看视频 | 久久蜜桃av一区二区天堂 | 日韩一二三区视频 |