全局索引global index 1.全局索引的分區鍵和分區數和表的分區鍵和分區數可能都不相同,表和全局索引的分區機制不一樣。 2.全局索引可以分區,也可以是不分區索引,全局索引必須是前綴索引,即全局索引的索引列必須是以索引分區鍵作為其前幾列。 3.全局索引可以依附于分區表;也可以依附于非分區表。 4.全局分區索引的索引條目可能指向若干個分區,因此,對于全局分區索引,即使只截斷一個分區中的數據,都需要rebulid若干個分區甚至是整個索引。 5.全局索引多應用于oltp系統中。 6.全局分區索引只按范圍或者散列分區,hash分區是10g以后才支持。 7.oracle9i以后對分區表做move或者truncate的時可以用update global indexes語句來同步更新全局分區索引,用消耗一定資源來換取高度的可用性。 8.表用a列作分區,索引用b做局部分區索引,若where條件中用b來查詢,那么oracle會掃描所有的表和索引的分區,成本會比分區更高,此時可以考慮用b做全局分區索引。
分區索引字典 DBA_PART_INDEXES 分區索引的概要統計信息,可以得知每個表上有哪些分區索引,分區索引的類型(local/global) Dba_ind_partitions 每個分區索引的分區級統計信息 Dba_indexes/dba_part_indexes 可以得到每個表上有哪些非分區索引 索引重建 Alter index idx_name rebuild partition index_partition_name [online nologging] 需要對每個分區索引做rebuild,重建的時候可以選擇online(不會鎖定表),或者nologging建立索引的時候不生成日志,加快速度。 Alter index rebuild idx_name [online nologging] 對非分區索引,只能整個index重建 分區索引實例
復制代碼 代碼如下:
--1、建分區表 CREATE TABLE P_TAB( C1 INT, C2 VARCHAR2(16), C3 VARCHAR2(64), C4 INT , CONSTRAINT PK_PT PRIMARY KEY (C1) ) PARTITION BY RANGE(C1)( PARTITION P1 VALUES LESS THAN (10000000), PARTITION P2 VALUES LESS THAN (20000000), PARTITION P3 VALUES LESS THAN (30000000), PARTITION P4 VALUES LESS THAN (MAXVALUE) ); --2、建全局分區索引 CREATE INDEX IDX_PT_C4 ON P_TAB(C4) GLOBAL PARTITION BY RANGE(C4) ( PARTITION IP1 VALUES LESS THAN(10000), PARTITION IP2 VALUES LESS THAN(20000), PARTITION IP3 VALUES LESS THAN(MAXVALUE) ); --3、建本地分區索引 CREATE INDEX IDX_PT_C2 ON P_TAB(C2) LOCAL (PARTITION P1,PARTITION P2,PARTITION P3,PARTITION P4); --4、建全局分區索引(與分區表分區規則相同的列上) CREATE INDEX IDX_PT_C1 ON P_TAB(C1) GLOBAL PARTITION BY RANGE (C1) ( PARTITION IP01 VALUES LESS THAN (10000000), PARTITION IP02 VALUES LESS THAN (20000000), PARTITION IP03 VALUES LESS THAN (30000000), PARTITION IP04 VALUES LESS THAN (MAXVALUE) ); --5、分區索引數據字典查看 SELECT * FROM USER_IND_PARTITIONS; SELECT * FROM USER_PART_INDEXES;