`
vvnet
  • 浏览: 112357 次
  • 性别: Icon_minigender_1
  • 来自: 青岛
社区版块
存档分类
最新评论

Orale分区索引

阅读更多

表可以按rangehashlist分区,表分区后,其上的索引和普通表上的索引有所不同,oracle对于分区表上的索引分为2类,即局部索引和全局索引,下面分别对这2种索引的特点和局限性做个总结。

局部索引local index

1.        局部索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区数,一句话,局部索引的分区机制和表的分区机制一样。

2.        如果局部索引的索引列以分区键开头,则称为前缀局部索引。

3.        如果局部索引的列不是以分区键开头,或者不包含分区键列,则称为非前缀索引。

4.        局部索引只能依附于分区表上

5.        前缀和非前缀索引都可以支持索引分区消除,前提是查询的条件中包含索引分区键。

6.        局部索引只支持分区内的唯一性,无法支持表上的唯一性,因此如果要用局部索引去给表做唯一性约束,则约束中必须要包括分区键列。

7.        局部分区索引是对单个分区的,每个分区索引只指向一个表分区;全局索引则不然,一个分区索引能指向n个表分区,同时,一个表分区,也可能指向n个索引分区,对分区表中的某个分区做truncate或者moveshrink等,可能会影响到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. --1、建分区表  
  2. CREATE TABLE P_TAB(  
  3. C1 INT,  
  4. C2 VARCHAR2(16),  
  5. C3 VARCHAR2(64),  
  6. C4 INT ,  
  7. CONSTRAINT PK_PT PRIMARY KEY (C1)  
  8. )  
  9. PARTITION BY RANGE(C1)(  
  10. PARTITION P1 VALUES LESS THAN (10000000),  
  11. PARTITION P2 VALUES LESS THAN (20000000),  
  12. PARTITION P3 VALUES LESS THAN (30000000),  
  13. PARTITION P4 VALUES LESS THAN (MAXVALUE)  
  14. );  
  15. --2、建全局分区索引  
  16. CREATE INDEX IDX_PT_C4 ON P_TAB(C4) GLOBAL PARTITION BY RANGE(C4)  
  17. (  
  18. PARTITION IP1 VALUES LESS THAN(10000),  
  19. PARTITION IP2 VALUES LESS THAN(20000),  
  20. PARTITION IP3 VALUES LESS THAN(MAXVALUE)  
  21. );  
  22. --3、建本地分区索引  
  23. CREATE INDEX IDX_PT_C2 ON P_TAB(C2) LOCAL (PARTITION P1,PARTITION P2,PARTITION P3,PARTITION P4);  
  24. --4、建全局分区索引(与分区表分区规则相同的列上)  
  25. CREATE INDEX IDX_PT_C1  
  26. ON P_TAB(C1)  
  27. GLOBAL PARTITION BY RANGE (C1)  
  28. (  
  29. PARTITION IP01 VALUES LESS THAN (10000000),  
  30. PARTITION IP02 VALUES LESS THAN (20000000),  
  31. PARTITION IP03 VALUES LESS THAN (30000000),  
  32. PARTITION IP04 VALUES LESS THAN (MAXVALUE)  
  33. );  
  34. --5、分区索引数据字典查看  
  35. SELECT * FROM USER_IND_PARTITIONS;  
  36. SELECT * FROM USER_PART_INDEXES; 
分享到:
评论

相关推荐

    分区索引,本地索引,全局索引的区别

    oracle 分区索引,本地索引,全局索引的区别

    ORACLE_分区表_分区索引_索引分区

    ORACLE 分区表 分区索引 索引分区 实例讲解

    深入oracle分区索引的详解

    局部索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区数,一句话,局部索引的分区机制和表的分区机制一样。2.如果局部索引的索引列以分区键开头,则称为前缀局部索引。3.如果局部索引的列不是以...

    oracle索引与分区索引介绍

    oracle索引与分区索引介绍 删除分区 分区合并(从中间删除掉一个分区,或者两个分区需要合并后减少分区数量) 创建新的分区 交换分区

    oracle分区表分区索引.docx

    对于oracle分区表分区索引的详细说明。 详细描述了分区表的类型,分区索引的类型 分类 。 删除或truncate 表分区时,什么样的情况索引会失效 需要重建 ,什么时候 对索引 没影响 。

    Oracle 分区表 分区索引

    如何创建,管理分区,分区索引。

    Oracle分区表及分区索引

    总结描述Oracle 11g分区表的种类及分区索引的类型。范围分区,列表分区,散列分区,组合分区,哈希分区,全局索引,分区索引

    ORACLE分区与索引

    对orcle大数据的查询的优化,ORACLE分区表、分区索引ORACLE对于分区表方式其实就是将表分段存储,一般普通表格是一个段存储,而分区表会分成多个段,所以查找数据过程都是先定位根据查询条件定位分区范围,即数据在...

    Oracle 分区表 分区索引 索引分区详解

    虽然存储介质和数据处理技术的发展也很快,但是仍然不能满足用户的需求,为了使用户的大量的数据在读写操作和查询中速度更快,Oracle提供了对表和索引进行分区的技术,以改善大型应用系统的性能。

    深入学习分区表及分区索引(详解oracle分区).docx

    深入学习分区表及分区索引(详解oracle分区).docx

    Oracle 分区索引介绍和实例演示

    分区索引(或索引分区)主要是针对分区表而言的。随着数据量的不断增长,普通的堆表需要转换到分区表,其索引呢,则对应的转换到分区索引。分区索引的好处是显而易见的。就是简单地把一个索引分成多个片断,在获取所需...

    oracle分区索引的失效和重建代码示例

    上一篇文章中我们了解了oracle普通表转化为分区表的方法的相关内容,接下来的这篇文章,我们将探讨oracle分区索引的失效和重建问题,提供了相关代码示例供大家参考,具体如下。 --创建测试表 SQL> create table t ...

    oracle分区与索引

    oracle分区与索引

    Oracle分区表和分区索引在VLDB中的研究.pdf

    Oracle分区表和分区索引在VLDB中的研究.pdf

    Oracle表分区和索引分区

    Oracle表分区和索引分区 分区概述 为了简化数据库大表的管理,例如在数据仓库中一般都是TB级的数量级.ORACLE8以后推出了分区选项.分区将表分离在若于不同的表空间上,用分而治之的方法来支撑元限膨胀的大表,组...

    ORACLE重建索引总结

    五、重建分区表上的分区索引 重建分区索引方法: Alter index indexname rebuild partition paritionname tablespace tablespacename; Alter index indexname rebuild subpartition partitioname tablespace ...

Global site tag (gtag.js) - Google Analytics