自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

DB2數(shù)據(jù)庫(kù)與Oracle并發(fā)控制(鎖)的大比拼

數(shù)據(jù)庫(kù)
本文主要向大家講述的是DB2數(shù)據(jù)庫(kù)和Oracle的并發(fā)控制(鎖)的比較,以及對(duì)其在實(shí)際操作中所要涉及到的相關(guān)操作細(xì)節(jié)的描述。

以下的文章主要向大家描述的是DB2數(shù)據(jù)庫(kù)和Oracle的并發(fā)控制(鎖)的比較,以下就是對(duì)DB2數(shù)據(jù)庫(kù)和Oracle的并發(fā)控制(鎖)的比較的描述,望會(huì)對(duì)你有所幫助,以下就是文章的主要內(nèi)容講述。

1 引言

 

在關(guān)系數(shù)據(jù)庫(kù)(DB2,Oracle,Sybase,Informix和SQL Server)最小的恢復(fù)和交易單位為一個(gè)事務(wù)(Transactions),事務(wù)具有ACID(原子性,一致性,隔離性和***性)特征。關(guān)系數(shù)據(jù)庫(kù)為了確保并發(fā)用戶(hù)在存取同一數(shù)據(jù)庫(kù)對(duì)象時(shí)的正確性(即無(wú)丟失更新、可重復(fù)讀、不讀"臟"數(shù)據(jù),無(wú)"幻像"讀),DB2數(shù)據(jù)庫(kù)中引入了并發(fā)(鎖)機(jī)制。基本的鎖類(lèi)型有兩種:排它鎖(Exclusive locks記為X鎖)和共享鎖(Share locks記為S鎖)。

排它鎖:若事務(wù)T對(duì)數(shù)據(jù)D加X(jué)鎖,則其它任何事務(wù)都不能再對(duì)D加任何類(lèi)型的鎖,直至T釋放D上的X鎖;一般要求在修改數(shù)據(jù)前要向該數(shù)據(jù)加排它鎖,所以排它鎖又稱(chēng)為寫(xiě)鎖。

共享鎖:若事務(wù)T對(duì)數(shù)據(jù)D加S鎖,則其它事務(wù)只能對(duì)D加S鎖,而不能加X(jué)鎖,直至T釋放D上的S鎖;一般要求在讀取數(shù)據(jù)前要向該數(shù)據(jù)加共享鎖,所以共享鎖又稱(chēng)為讀鎖。

2 DB2 多粒度封鎖機(jī)制介紹

2.1 鎖的對(duì)象

DB2支持對(duì)表空間、表、行和索引加鎖(大型機(jī)上的DB2數(shù)據(jù)庫(kù)還可以支持對(duì)數(shù)據(jù)頁(yè)加鎖)來(lái)保證數(shù)據(jù)庫(kù)的并發(fā)完整性。不過(guò)在考慮用戶(hù)應(yīng)用程序的并發(fā)性的問(wèn)題上,通常并不檢查用于表空間和索引的鎖。該類(lèi)問(wèn)題分析的焦點(diǎn)在于表鎖和行鎖。

2.2 鎖的策略

DB2可以只對(duì)表進(jìn)行加鎖,也可以對(duì)表和表中的行進(jìn)行加鎖。如果只對(duì)表進(jìn)行加鎖,則表中所有的行都受到同等程度的影響。如果加鎖的范圍針對(duì)于表及下屬的行,則在對(duì)表加鎖后,相應(yīng)的數(shù)據(jù)行上還要加鎖。究竟應(yīng)用程序是對(duì)表加行鎖還是同時(shí)加表鎖和行鎖,是由應(yīng)用程序執(zhí)行的命令和系統(tǒng)的隔離級(jí)別確定。

2.2.1 DB2表鎖的模式

DB2在表一級(jí)加鎖可以使用以下加鎖方式:

表一:DB2數(shù)據(jù)庫(kù)表鎖的模式

下面對(duì)幾種表鎖的模式進(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ù),并最終可以通過(guò)獲得表上的X鎖來(lái)得到對(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鎖用于表上以允許未提交讀這一概念。

2.2.2 DB2行鎖的模式

除了表鎖之外,DB2還支持以下幾種方式的行鎖。以上的相關(guān)內(nèi)容就是對(duì)DB2數(shù)據(jù)庫(kù)和Oracle的并發(fā)控制(鎖)的比較的介紹,望你能有所收獲。

【編輯推薦】

  1. DB2 LOAD命令所提供的選項(xiàng)及注冊(cè)表變量大全
  2. DB2快照函數(shù)全解析經(jīng)典版
  3. DB2:信息管理 盡在掌握
  4. DB2 9 XML 性能優(yōu)勢(shì)
  5. DB2 V7存儲(chǔ)過(guò)程構(gòu)建環(huán)境設(shè)置的正確操作步驟描述
責(zé)任編輯:佚名 來(lái)源: 中國(guó)IDC圈
相關(guān)推薦

2009-11-16 09:05:47

PostgreSQLInnoDB多版本并發(fā)控制

2023-11-14 09:00:00

向量數(shù)據(jù)庫(kù)ChromaMilvus

2010-09-07 09:31:03

DB2數(shù)據(jù)庫(kù)鎖表

2023-05-26 15:53:48

MidjourneyAI圖像

2019-07-13 15:00:17

結(jié)構(gòu)化SQLNOSQL數(shù)據(jù)庫(kù)

2009-10-13 14:46:00

思科認(rèn)證

2010-04-21 12:54:46

Unix內(nèi)核

2019-08-27 09:00:00

敏捷開(kāi)發(fā)開(kāi)發(fā)方法項(xiàng)目

2019-10-23 15:06:23

HadoopMongoDB數(shù)據(jù)庫(kù)

2010-08-04 13:30:49

2010-08-16 14:45:15

DB2數(shù)據(jù)庫(kù)

2020-08-04 17:06:40

Merging Rebasing Git

2009-07-06 17:34:26

遠(yuǎn)程復(fù)制DB2

2010-03-18 14:54:46

主流無(wú)線(xiàn)技術(shù)

2011-01-19 11:10:30

2010-08-10 10:07:29

DB2 數(shù)據(jù)庫(kù)

2010-08-04 11:18:09

2011-03-11 16:02:03

DB2數(shù)據(jù)庫(kù)安裝

2010-07-30 09:30:14

DB2數(shù)據(jù)庫(kù)

2024-07-19 08:33:56

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)