DB2 數(shù)據(jù)庫表鎖的模式的描述
此文章主要講述的是DB2 數(shù)據(jù)庫表鎖的模式,如果你對(duì)DB2 數(shù)據(jù)庫表鎖的模式有興趣的話你就可以對(duì)以下的文章點(diǎn)擊觀看了,以下就是文章的主要內(nèi)容的詳細(xì)描述,望大家在瀏覽之后會(huì)對(duì)其有更深的了解。
DB2在表一級(jí)加鎖可以使用以下加鎖方式:
表一:DB2數(shù)據(jù)庫表鎖的模式
下面對(duì)幾種DB2 數(shù)據(jù)庫表鎖的模式進(jìn)一步加以闡述:
IS、IX、SIX方式用于表一級(jí)并需要行鎖配合,他們可以阻止其他應(yīng)用程序?qū)υ摫砑由吓潘i。
如果一個(gè)應(yīng)用程序獲得某表的IS鎖,該應(yīng)用程序可獲得某一行上的S鎖,用于只讀操作,同時(shí)其他應(yīng)用程序也可以讀取該行,或是對(duì)表中的其他行進(jìn)行更改。
如果一個(gè)應(yīng)用程序獲得某表的IX鎖,該應(yīng)用程序可獲得某一行上的X鎖,用于更改操作,同時(shí)其他應(yīng)用程序可以讀取或更改表中的其他行。
如果一個(gè)應(yīng)用程序獲得某表的SIX鎖,該應(yīng)用程序可以獲得某一行上的X鎖,用于更改操作,同時(shí)其他應(yīng)用程序只能對(duì)表中其他行進(jìn)行只讀操作。
S、U、X和Z方式用于表一級(jí),但并不需要行鎖配合,是比較嚴(yán)格的表加鎖策略。
如果一個(gè)應(yīng)用程序得到某表的S鎖。該應(yīng)用程序可以讀表中的任何數(shù)據(jù)。同時(shí)它允許其他應(yīng)用程序獲得該表上的只讀請(qǐng)求鎖。如果有應(yīng)用程序需要更改讀該表上的數(shù)據(jù),必須等S鎖被釋放。
如果一個(gè)應(yīng)用程序得到某表的U鎖,該應(yīng)用程序可以讀表中的任何數(shù)據(jù),并最終可以通過獲得表上的X鎖來得到對(duì)表中任何數(shù)據(jù)的修改權(quán)。其他應(yīng)用程序只能讀取該表中的數(shù)據(jù)。U鎖與S鎖的區(qū)別主要在于更改的意圖上。U鎖的設(shè)計(jì)主要是為了避免兩個(gè)應(yīng)用程序在擁有S鎖的情況下同時(shí)申請(qǐng)X鎖而造成死鎖的。
如果一個(gè)應(yīng)用程序得到某表上的X鎖,該應(yīng)用程序可以讀或修改表中的任何數(shù)據(jù)。其他應(yīng)用程序不能對(duì)該表進(jìn)行讀或者更改操作。
如果一個(gè)應(yīng)用程序得到某表上的Z鎖,該應(yīng)用程序可以讀或修改表中的任何數(shù)據(jù)。其他應(yīng)用程序,包括未提交讀程序都不能對(duì)該表進(jìn)行讀或者更改操作。
IN鎖用于表上以允許未提交讀這一概念。以上的相關(guān)內(nèi)容就是對(duì) DB2 數(shù)據(jù)庫表鎖的模式的介紹,望你能有所收獲。
【編輯推薦】
- DB2數(shù)據(jù)庫上建立數(shù)據(jù)庫分區(qū)與命令
- IBM DB2數(shù)據(jù)庫無限活動(dòng)的日志策略的破解
- 對(duì)DB2服務(wù)器主機(jī)名的修改的正確操作流程
- 使用DB2數(shù)據(jù)庫時(shí)哪些知識(shí)點(diǎn)是必須記住的?
- DB2 batch update在實(shí)際操作中的注意事項(xiàng)