• 售前

  • 售后

热门帖子
入门百科

深入oracle分区索引的详解

[复制链接]
喜欢头像那女纸 显示全部楼层 发表于 2021-10-26 12:34:23 |阅读模式 打印 上一主题 下一主题
表可以按range、hash、list分区,表分区后,其上的索引和普通表上的索引有所差别,oracle对于分区表上的索引分为2类,即局部索引和全局索引,下面分别对这2种索引的特点和局限性做个总结。

局部索引local index
1.局部索引肯定是分区索引,分区键等同于表的分区键,分区数等同于表的分区数,一句话,局部索引的分区机制和表的分区机制一样。
2.假如局部索引的索引列以分区键开头,则称为前缀局部索引。
3.假如局部索引的列不是以分区键开头,大概不包罗分区键列,则称为非前缀索引。
4.局部索引只能依附于分区表上。
5.前缀和非前缀索引都可以支持索引分区消除,条件是查询的条件中包罗索引分区键。
6.局部索引只支持分区内的唯一性,无法支持表上的唯一性,因此假如要用局部索引去给表做唯一性束缚,则束缚中必须要包括分区键列。
7.局部门区索引是对单个分区的,每个分区索引只指向一个表分区;全局索引则不然,一个分区索引能指向n个表分区,同时,一个表分区,也可能指向n个索引分区,对分区表中的某个分区做truncate大概move,shrink等,可能会影响到n个全局索引分区,正由于这点,局部门区索引具有更高的可用性。
8.位图索引只能为局部门区索引。
9.局部索引多应用于数据堆栈环境中。

全局索引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;

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作