成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

DB2數據庫與Oracle并發控制(鎖)的大比拼

數據庫
本文主要向大家講述的是DB2數據庫和Oracle的并發控制(鎖)的比較,以及對其在實際操作中所要涉及到的相關操作細節的描述。

以下的文章主要向大家描述的是DB2數據庫和Oracle的并發控制(鎖)的比較,以下就是對DB2數據庫和Oracle的并發控制(鎖)的比較的描述,望會對你有所幫助,以下就是文章的主要內容講述。

1 引言

 

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

排它鎖:若事務T對數據D加X鎖,則其它任何事務都不能再對D加任何類型的鎖,直至T釋放D上的X鎖;一般要求在修改數據前要向該數據加排它鎖,所以排它鎖又稱為寫鎖。

共享鎖:若事務T對數據D加S鎖,則其它事務只能對D加S鎖,而不能加X鎖,直至T釋放D上的S鎖;一般要求在讀取數據前要向該數據加共享鎖,所以共享鎖又稱為讀鎖。

2 DB2 多粒度封鎖機制介紹

2.1 鎖的對象

DB2支持對表空間、表、行和索引加鎖(大型機上的DB2數據庫還可以支持對數據頁加鎖)來保證數據庫的并發完整性。不過在考慮用戶應用程序的并發性的問題上,通常并不檢查用于表空間和索引的鎖。該類問題分析的焦點在于表鎖和行鎖。

2.2 鎖的策略

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

2.2.1 DB2表鎖的模式

DB2在表一級加鎖可以使用以下加鎖方式:

表一:DB2數據庫表鎖的模式

下面對幾種表鎖的模式進一步加以闡述:

IS、IX、SIX方式用于表一級并需要行鎖配合,他們可以阻止其他應用程序對該表加上排它鎖。

如果一個應用程序獲得某表的IS鎖,該應用程序可獲得某一行上的S鎖,用于只讀操作,同時其他應用程序也可以讀取該行,或是對表中的其他行進行更改。

如果一個應用程序獲得某表的IX鎖,該應用程序可獲得某一行上的X鎖,用于更改操作,同時其他應用程序可以讀取或更改表中的其他行。

如果一個應用程序獲得某表的SIX鎖,該應用程序可以獲得某一行上的X鎖,用于更改操作,同時其他應用程序只能對表中其他行進行只讀操作。

S、U、X和Z方式用于表一級,但并不需要行鎖配合,是比較嚴格的表加鎖策略。

如果一個應用程序得到某表的S鎖。該應用程序可以讀表中的任何數據。同時它允許其他應用程序獲得該表上的只讀請求鎖。如果有應用程序需要更改讀該表上的數據,必須等S鎖被釋放。

如果一個應用程序得到某表的U鎖,該應用程序可以讀表中的任何數據,并最終可以通過獲得表上的X鎖來得到對表中任何數據的修改權。其他應用程序只能讀取該表中的數據。U鎖與S鎖的區別主要在于更改的意圖上。U鎖的設計主要是為了避免兩個應用程序在擁有S鎖的情況下同時申請X鎖而造成死鎖的。

如果一個應用程序得到某表上的X鎖,該應用程序可以讀或修改表中的任何數據。其他應用程序不能對該表進行讀或者更改操作。

如果一個應用程序得到某表上的Z鎖,該應用程序可以讀或修改表中的任何數據。其他應用程序,包括未提交讀程序都不能對該表進行讀或者更改操作。

IN鎖用于表上以允許未提交讀這一概念。

2.2.2 DB2行鎖的模式

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

【編輯推薦】

  1. DB2 LOAD命令所提供的選項及注冊表變量大全
  2. DB2快照函數全解析經典版
  3. DB2:信息管理 盡在掌握
  4. DB2 9 XML 性能優勢
  5. DB2 V7存儲過程構建環境設置的正確操作步驟描述
責任編輯:佚名 來源: 中國IDC圈
相關推薦

2009-11-16 09:05:47

PostgreSQLInnoDB多版本并發控制

2010-09-07 09:31:03

DB2數據庫鎖表

2023-11-14 09:00:00

向量數據庫ChromaMilvus

2023-05-26 15:53:48

MidjourneyAI圖像

2010-08-04 13:30:49

2019-07-13 15:00:17

結構化SQLNOSQL數據庫

2010-04-21 12:54:46

Unix內核

2019-08-27 09:00:00

敏捷開發開發方法項目

2009-07-06 17:34:26

遠程復制DB2

2010-08-16 14:45:15

DB2數據庫

2019-10-23 15:06:23

HadoopMongoDB數據庫

2010-08-10 10:07:29

DB2 數據庫

2010-08-04 11:18:09

2011-03-11 16:02:03

DB2數據庫安裝

2010-07-30 09:30:14

DB2數據庫

2020-08-04 17:06:40

Merging Rebasing Git

2011-01-19 11:10:30

2010-08-17 16:24:32

IBM DB2數據庫

2009-10-13 14:46:00

思科認證

2010-08-05 14:58:57

DB2數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲人人舔人人 | 精品一区在线免费观看 | www.久久影视| 91视频在线| 天堂资源最新在线 | 青青99 | 91porn国产成人福利 | 一级黄色生活视频 | 日韩一区二区三区视频在线播放 | 成人免费影院 | 中文字幕成人av | 7777精品伊人久久精品影视 | 欧美日韩国产一区二区三区不卡 | 精产国产伦理一二三区 | 黄色a视频 | 九九九精品视频 | 97色在线视频 | 日本黄色一级片视频 | 成人免费在线观看 | 日本二区在线观看 | 国产乱码精品1区2区3区 | 99精品一级欧美片免费播放 | 亚洲日本免费 | 亚洲高清在线 | 欧美国产一区二区 | wwww.8888久久爱站网 | 日韩精品免费在线 | 在线视频一区二区 | 热久久免费视频 | 成人二区 | 91久久久久久久久久久久久 | 欧美成人一区二免费视频软件 | 日本理论片好看理论片 | 日韩国产一区 | 精品中文在线 | 国产无人区一区二区三区 | 亚洲一二三区不卡 | 精品久久久久久久久久 | 欧美一区二区三区久久精品 | 欧美日韩电影一区二区 | 老司机免费视频 |