Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1153618
  • 博文数量: 231
  • 博客积分: 2500
  • 博客等级: 少校
  • 技术积分: 2662
  • 用 户 组: 普通用户
  • 注册时间: 2009-11-03 16:35
个人简介

学无止境

文章分类

全部博文(231)

文章存档

2014年(7)

2013年(103)

2011年(11)

2010年(53)

2009年(57)

分类: Oracle

2013-09-22 12:43:09

分区索引,分为局部索引和全局索引,还根据索引列是否以分区键开头,分为前缀索引和非前缀索引。
一些名词的解释:
 
局部索引:局部索引一定是分区索引,在建立索引的时候,加上loccal关键字,该索引的分区键等同于表的分区键,但索引中不一定需要包含分区键字段。
 
全局索引:全局索引可以分区索引,也可以是不分区索引类似普通索引,但全局分区索引必须包含分区键开头,即必须有前缀。如果表有多个分区键,全局索引可以只包含其中一个分区键。
 
前缀索引:以分区键开头的索引,称为前缀索引。
 
非前缀索引:如果局部索引的列不是以分区键开头,或者不包含分区键列,则称为非前缀索引,只有局部索引才能是非前缀索引。
 
索引分区消除:在执行SQL时,只需要访问分区索引的一部分,称为索引分区消除,前缀和非前缀索引都可以支持索引分区消除,前提是查询的条件中包含索引分区键。
 
索引分区数和表分区数的关系:全局索引的分区键和分区数和表的分区键和分区数可能都不相同,局部索引的分区数量与表分区数量相同。
 
 
以下是分区索引的例子:
PART_TAB1表是根据ttime字段的范围分区,表分区数量为8。
建立全局分区索引,分区方式可以和表分区不同,分区数量也可以和表分区数量不同,但是分区键必须和表的分区键相同。如果表有多个分区键,全局索引可以只包含其中一个分区键。
局部索引的分区方式必须和表分区方式相同
 
create index idx_g_ptab1 on PART_TAB1(ttime,name) global partition by hash (ttime) partitions 3;
create index idx_g_ptab2 on PART_TAB1(id) local;
 
SQL> select index_name,partitioning_type,partition_count,locality,alignment from user_part_indexes where table_name='PART_TAB1';
 
INDEX_NAME                     PARTITI PARTITION_COUNT LOCALI ALIGNMENT
------------------------------ ------- --------------- ------ ------------
IDX_G_PTAB1                    HASH                  3 GLOBAL PREFIXED
IDX_G_PTAB2                    RANGE                 8 LOCAL  NON_PREFIXED
 
 
 
局部索引local index
 
1.局部索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区说,一句话,局部索引的分区机制和表的分区机制一样。
2.如果局部索引的索引列以分区键开头,则称为前缀局部索引。
3.如果局部索引的列不是以分区键开头,或者不包含分区键列,则称为非前缀索引。
4.前缀和非前缀索引都可以支持索引分区消除,前提是查询的条件中包含索引分区键。
5.局部索引只支持分区内的唯一性,无法支持表上的唯一性,因此如果要用局部索引去给表做唯一性约束,则约束中必须要包括分区键列。
6.局部分区索引是对单个分区的,每个分区索引只指向一个表分区,全局索引则不然,一个分区索引能指向n个表分区,同时,一个表分区,也可能指向n个索引分区,对分区表中的某个分区做truncate或者move,shrink等,可能会影响到n个全局索引分区,正因为这点,局部分区索引具有更高的可用性。
7.位图索引只能为局部分区索引。
8.局部索引多应用于数据仓库环境中。
 
全局索引global index
 
1.全局索引的分区键和分区数和表的分区键和分区数可能都不相同,表和全局索引的分区机制不一样。
2.全局索引可以分区,也可以是不分区索引(即为普通索引),全局分区索引必须是前缀索引,即全局索引的索引列必须是以索引分区键作为其前几列。
3.全局分区索引的索引条目可能指向若干个分区,因此,对于全局分区索引,即使只动,截断一个分区中的数据,都需要rebulid若干个分区甚至是整个索引。
4.全局索引多应用于oltp系统中。
5.全局分区索引只按范围或者散列hash分区,hash分区是10g以后才支持。
6.oracle9i以后对分区表做move或者truncate的时可以用update global indexes语句来同步更新全局分区索引,用消耗一定资源来换取高度的可用性。
7.表用a列作分区,索引用b做局部分区索引,若where条件中用b来查询,那么oracle会扫描所有的表和索引的分区,成本会比分区更高,此时可以考虑用b做全局分区索引
 
 
监控索引是否有被使用
 
找出不必要的索引,既可以减少空间开销,又可能减少DML维护的开销。
监视索引使用
ALTER INDEX customers_pk MONITORING USAGE;
ALTER INDEX customers_pk NOMONITORING USAGE;
查看V$OBJECT_USAGE视图,看监视时间内是否有用过索引。
阅读(858) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~