ORACLE索引聚簇表的數(shù)據(jù)加載
來源:易賢網(wǎng) 閱讀:919 次 日期:2014-08-25 11:13:41
溫馨提示:易賢網(wǎng)小編為您整理了“ORACLE索引聚簇表的數(shù)據(jù)加載”,方便廣大網(wǎng)友查閱!

一:首先介紹一下索引聚簇表的工作原理:

聚簇是指:如果一組表有一些共同的列,則將這樣一組表存儲在相同的數(shù)據(jù)庫塊中;聚簇還表示把相關的數(shù)據(jù)存儲在同一個塊上。利用聚簇,一個塊可能包含多個表的數(shù)據(jù)。概念上就是如果兩個或多個表經(jīng)常做鏈接操作,那么可以把需要的數(shù)據(jù)預先存儲在一起。聚簇還可以用于單個表,可以按某個列將數(shù)據(jù)分組存儲。

更加簡單的說,比如說,EMP表和DEPT表,這兩個表存儲在不同的segment中,甚至有可能存儲在不同的TABLESPACE中,因此,他們的數(shù)據(jù)一定不會在同一個BLOCK里。而我們有會經(jīng)常對這兩個表做關聯(lián)查詢,比如說:select * from emp,dept where emp.deptno = dept.deptno .仔細想想,查詢主要是對BLOCK的操作,查詢的BLOCK越多,系統(tǒng)IO就消耗越大。如果我把這兩個表的數(shù)據(jù)聚集在少量的BLOCK里,查詢效率一定會提高不少。

比如我現(xiàn)在將值deptno=10的所有員工抽取出來,并且把對應的部門信息也存儲在這個BLOCK里(如果存不下了,可以為原來的塊串聯(lián)另外的塊)。這就是索引聚簇表的工作原理。

二:創(chuàng)建過程。

索引聚簇表是基于一個索引聚簇(index cluster)創(chuàng)建的。里面記錄的是各個聚簇鍵。聚簇鍵和我們用得做多的索引鍵不一樣,索引鍵指向的是一行數(shù)據(jù),聚簇鍵指向的是一個ORACLE BLOCK。我們可以先通過以下命令創(chuàng)建一個索引簇。

SQL> conn scott/tiger

已連接。

SQL> desc dept

名稱 是否為空? 類型

----------------------------------------- -------- ----------------------------

DEPTNO NOT NULL NUMBER(2)

DNAME VARCHAR2(14)

LOC VARCHAR2(13)

SQL> create cluster emp_dept_cluster

2 ( deptno number(2) )

3 size 1024

4 /

簇已創(chuàng)建。

這個名字可以用戶定義,不一定叫deptno,數(shù)據(jù)類型必須和需要使用這個聚簇的數(shù)據(jù)類型一致NUMBER(2)。在這里最關鍵的一個參數(shù)是size。這個選項原來告訴Oracle:我們希望與每個聚簇鍵值關聯(lián)大約1024字節(jié)的數(shù)據(jù)(1024對于一般的表一條數(shù)據(jù)沒問題),Oracle會在用這個數(shù)據(jù)庫塊上設置來計算每個塊最 多能放下多少個聚簇鍵。假設塊大小為8KB,Oracle會在每個數(shù)據(jù)庫塊上放上最多7個聚簇鍵,也就是說,對應部門10、20、30、40、50、60和70的數(shù)據(jù)會放在一個塊上,一旦插入部門80,就會使用一個新塊。存放的數(shù)據(jù)是和插入順序相關的。

因 此,SIZE測試控制著每塊上聚簇鍵的最大個數(shù)。這是對聚簇空間利用率影響最大的因素。如果把這個SIZE設置得太高,那么每個塊上的鍵就會很少(單位BLOCK可以存的聚簇鍵就少了),我們會不必要地使用更多的空間。如果設置得太低,又會導致數(shù)據(jù)過分串鏈(一個聚簇鍵不夠存放一條數(shù)據(jù)),這又與聚簇本來的目的不符,因為聚簇原本是為了把所有相關數(shù)據(jù)都存儲在一個塊上。

向聚簇中放數(shù)據(jù)之前,需要先對聚簇建立索引??梢袁F(xiàn)在就在聚簇中創(chuàng)建表,但是由于我們想同時創(chuàng)建和填充表,而有數(shù)據(jù)之前必須有一個聚簇索引,所以我們先來建立聚簇索引。

更多信息請查看IT技術專欄

更多信息請查看數(shù)據(jù)庫
易賢網(wǎng)手機網(wǎng)站地址:ORACLE索引聚簇表的數(shù)據(jù)加載

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網(wǎng)