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

對DB2 V9.7 本地分區索引的詳細描述

數據庫
以下的文章主要向大家描述的是DB2 V9.7 本地分區索引的介紹,以及對DB2 V9.7 數據庫其提出了范圍分區表的分區索引的實際操作的概念的描述。

此文章主要講述的是DB2 V9.7 本地分區索引的介紹,DB2 V9.7 數據庫其提出了范圍分區表的分區索引的實際操作的概念,這主要是為客戶在原有的全局索引基礎上增加了一個新的功能選擇。

分區索引采用 B 樹結構,將一棵全局大樹分解為諾干個小樹,樹的層次將會顯著減少,這將會提高數據的插入、更新、刪除和掃描的性能。分區索引在分區表的 Roll in/Roll out 時不需要重新構建整個索引,加速了數據的滾入和滾出。

簡介

在 DB2 V9.7 以前,范圍分區表只支持全局索引(或者稱為非分區索引),這樣即使分區表的數據是分布在多個表空間上的,分區表的所有索引只能存儲在同一個表空間中。這一特性限制了索引掃描只能在一個表空間上對該索引的頁面進行讀取,導致讀取頁面過多并約束了掃描的并行性。

DB2 V9.7 使用分區索引的索引組織方案,即索引數據根據表的分區方案分布到多個索引分區中,每個索引分區都只引用對應數據分區中的表行。從 DB2 V9.7 開始,創建索引時默認創建分區索引,除非出現以下情況:

對 CREATE INDEX 語句指定了 UNIQUE,并且索引鍵未包括所有表分區鍵列。

創建基于空間數據的索引。

 

創建基于 XML 數據的索引

 

分區索引的創建

 

一個分區表可以同時存在分區索引和非分區索引。如果創建分區索引,那個每個索引分區將都包含單個數據分區的索引條目,索引葉子節點中的 RID 也將只指向單個數據分區。

在我們使用 Alter table 語句的 Attach Partition 子句將數據 Roll in 或者 Roll Out 分區表時,分區索引將特別有用。如果使用非分區索引,那么必須先發出 Set Integrity 語句,新添加的分區中的數據才能進入聯機狀態。這個過程可能非常消耗時間,并可能消耗大量日志空間。當使用分區索引時這些開銷將會被消除。

分區索引的每個分區均采用 B 樹結構存儲,由于分區后一個大型 B 樹被劃分為若干小型 B 樹,樹的層數將會減少,這會提高數據的插入、更新、刪除以及掃描的性能。同時我們執行查詢時,DB2 將會采用分區消除優化方法提高掃描性能和并行性。分區消除技術幫助優化器先過濾了不需要的索引分區,只需要掃描相應的分區就能完成查詢,這比掃描非分區的索引更為高效。

清單 1. 創建示例分區表與索引

 

 

  1. CREATE TABLE t1 ( l_orderkey INTEGER, l_partkey INTEGER, l_suppkey INTEGER,  
  2. l_shipdate date, padding1 char(30) )   
  3. PARTITION BY RANGE(l_shipdate)   
  4. (   
  5. partition quarter01 STARTING '2008-01-01' ENDING '2008-03-31'in DMS_D1,   
  6. partition quarter02 STARTING '2008-04-01' ENDING '2008-06-30'in DMS_D2,   
  7. partition quarter03 STARTING '2008-07-01' ENDING '2008-09-30' in DMS_D3,   
  8. partition quarter04 STARTING '2008-10-01' ENDING '2008-12-31' in DMS_D4   
  9. );   
  10. Create index idx_t1_l_orderkey on t1(l_orderkey) NOT partitioned ;   
  11. Create index idx_t1_l_partkey on t1(l_partkey) partitioned;   

上面代碼中,我們創建了一個擁有四個分區的范圍分區表,同時創建了兩個索引。索引 index idx_t1_l_orderkey 是非分區索引,idx_t1_l_partkey 是分區索引。

我們下面查看一下上面代碼執行后數據字典關于表 T1 以及它的索引的描述。系統視圖 syscat.datapartitions 中包含了分區表的分區信息以及相關統計信息,系統視圖 syscat.indexpartitions 中則包含了分區索引的分區信息和相關統計信息。

清單 2. 分區表的數據分區信息

 

  1. db2 "select substr(TABNAME ,1,10) t_name,substr(DATAPARTITIONNAME ,1,10) part_name,   
  2. DATAPARTITIONID ,substr(LOWVALUE,1,12) low_value,substr(HIGHVALUE,1,12) high_value   
  3. from syscat.datapartitions where tabname='T1'"   
  4. T_NAME PART_NAME DATAPARTITIONID TBSPACEID LOW_VALUE HIGH_VALUE ----------   
  5. T1 QUARTER01 0 8 '2008-01-01' '2008-03-31'   
  6. T1 QUARTER02 1 9 '2008-04-01' '2008-06-30'   
  7. T1 QUARTER03 2 10 '2008-07-01' '2008-09-30'   
  8. T1 QUARTER04 3 11 '2008-10-01' '2008-12-31'   

清單 2 中代碼執行查詢,從系統視圖 syscat.datapartitions 中獲取關于數據分區的信息。查詢結果顯示,表 T1 具有四個分區,名稱與我們創建時相同,ID 依次為 0、1、2、3,數據分布在表空間 DMS_D1(ID 為 8)、DMS_D2(ID 為 9)、DMS_D2(ID 為 10)、DMS_D3(ID 為 11)上。本例中的表空間信息如下:

清單 3. 表空間信息

 

 

  1. db2 "select substr(TBSPACE,1,18) tablespace_name,TBSPACEID ,TBSPACETYPE   
  2. from syscat.tablespaces"   
  3. TABLESPACE_NAME TBSPACEID TBSPACETYPE   
  4. SYSCATSPACE 0 D TEMPSPACE1 1 S USERSPACE1 2 D   
  5. IBMDB2SAMPLEREL 3 D IBMDB2SAMPLEXML 4 D SYSTOOLSPACE 5 D   
  6. SYSTOOLSTMPSPACE 6 S TBS_TEST 7 D   
  7. DMS_D1 8 D DMS_D2 9 D DMS_D3 10 D DMS_D4 11 D DMS_I1 12 D   

清單 4. 索引基本信息

 

  1. db2 "select substr(tabname,1,10) tab_name, substr(INDNAME,1,18) inx_name,TBSPACEID   
  2. from syscat.indexes where tabname='T1'"   
  3. TAB_NAME INX_NAME TBSPACEID ---------- ------------------ -----------   
  4. T1 IDX_T1_L_ORDERKEY   
  5. 8   
  6. T1 IDX_T1_L_PARTKEY 65530   

我們看到非分區索引 IDX_T1_L_ORDERKEY 數據存放在表空間 DMS_D1 上(ID 為 8),這意味著在創建索引未明確指定表空間時,DB2 將使用***個數據分區所在的表空間存放非分區索引。而索引 IDX_T1_L_PARTKEY 所在的表空間 ID 為 65530,我們通過表空間信息部分看到我們的數據庫中沒有 ID 為 65530 表空間。

由于分區索引的存儲特性是和數據分區關聯的,一個索引將分布在多個表空間中,因此 DB2 用了 65530 特殊值表示索引的表空間,并不表示這個 ID 對應的表空間存在以上的相關內容就是對DB2 V9.7 本地分區索引的介紹,望你能有所收獲。

完整內容的學習,請訪問:

http://www.ibm.com/developerworks/cn/data/library/techarticles/dm-0907luohq/

【編輯推薦】

  1. DB2數據庫雙機的正確安裝流程描述
  2. DB2占用端口號如何在Linux或Unix下查看?
  3. 實現DB2數據庫安裝的操作過程描述
  4. 實現DB2數據庫恢復的路如何走好?
  5. 對DB2數據庫賬戶以及用戶標識的正確認識

     

     
責任編輯:佚名 來源: kejiweb.com
相關推薦

2010-08-10 10:42:27

DB2 V9.7

2010-08-16 16:08:34

DB2 V9.7

2010-08-16 13:53:26

2010-07-29 13:34:35

DB2編目

2010-08-19 09:22:03

DB2 V9.7 分區

2010-08-10 10:23:16

IBM DB2 V9.

2010-08-19 09:37:41

DB2 V9.7 語句

2010-08-19 08:49:41

DB2 V9.7 索引

2010-08-16 11:34:11

IBM DB2 V9.

2010-08-11 11:39:06

IBM DB2 V9.

2010-08-03 14:05:26

DB2數據集

2010-08-06 14:52:13

DB2 9.7武器

2010-08-03 13:29:44

DB2 9數據庫優點

2010-09-07 16:34:47

DB2 XML

2010-08-10 17:24:15

2010-08-11 09:56:20

DB2 V9.7

2010-08-19 16:47:14

DB2 9.5分區管理

2010-08-10 11:01:12

DB2 V9.7

2010-08-04 09:50:35

DB2 9存儲過程

2010-08-10 13:44:51

DB2創建外鍵
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区二区中文字幕 | 日韩国产高清在线观看 | 青青草视频网站 | 午夜精品久久久久久久星辰影院 | 亚洲一区二区精品视频在线观看 | 中文字幕成人av | 国产9999精品| 国产精品成人一区二区 | 天天看天天干 | 蜜桃黄网| 黄色操视频 | 超碰在线人人干 | 91欧美激情一区二区三区成人 | 欧美精品一区在线 | 一区二区三区四区免费观看 | 黑人精品欧美一区二区蜜桃 | 亚洲一区亚洲二区 | 久久国产精品视频免费看 | 久久国产精品免费一区二区三区 | 欧美一区二区三区在线播放 | 性色av一区 | 日韩欧美一级片 | 精品国产一区二区久久 | 国产一区二区三区在线 | 一区二区在线免费观看视频 | 性生生活大片免费看视频 | 欧美日韩在线播放 | 91电影在线播放 | 久久久精品一区 | 日韩在线一区二区三区 | 综合精品在线 | 欧美偷偷 | 自拍偷拍中文字幕 | 成人午夜精品 | 久久精品中文字幕 | 亚洲精品一区二三区不卡 | 久久精片| 国产精品91网站 | 成人一区二区三区视频 | av天天干| 蜜桃视频成人 |