在Oracle中,索引和表一样也可以分区。有两种类型的分区索引,本地分区索引(Local)和全局分区索引(Global)。
1、本地索引(Local)
本地分区索引使用LOCAL关键字创建,其分区边界与表相同(即与每个表分区相关联都有一个索引分区),下面是一个本地分区索引的例子:
create table sales_par
partitioned by range (year)
( partition p_2009 values less than (2010)
partition p_2010 values less than (2011),
partition p_2011 values less than (2012),
partition p_2012 values less than (2013)
)
as select * from sales;
--创建本地分区索引
create index sales_idx1 on sales_par (product,year) local;
可以看出,创建本地分区索引的语句非常简单,不需要指定分区边界,因为它的分区边界和表的一样。其示意图如下:
本地分区索引有如下基本特征:
1. 本地索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区说,总之,本地索引的分区机制和表的分区机制一模一样。
2. 如果本地索引的索引列以分区键开头,则称为前缀局部索引。
3. 如果本地索引的列不是以分区键开头,或者不包含分区键列,则称为非前缀索引。
4. 前缀和非前缀索引都可以支持索引分区消除,前提是查询的条件中包含索引分区键。
5. 本地索引只支持分区内的唯一性,无法支持表上的唯一性,因此如果要用本地索引去给表做唯一性约束,则约束中必须要包括分区键列。
6. 本地分区索引是对单个分区的,每个分区索引只指向一个表分区,全局索引则不然,一个分区索引能指向n个表分区,同时,一个表分区,也可能指向n个索引分区,对分区表中的某个分区做truncate或者move,shrink等,可能会影响到n个全局索引分区,正因为这点,本地分区索引具有更高的可用性。
7. 位图索引只能为本地分区索引。
8. 本地索引多应用于OLAP环境中。
索引分区消除
如果本地分区索引包含分区键并且SQL语句中的谓词条件包含分区键,执行计划通常仅需要访问一个或很少的索引分区,这种特性叫分区消除(Partition Elimination),分区消除可以有效地减少扫描数据块,提高查询性能,如:
--查询1:
select * from sales_par where product = 'CPU' and year = 2011;
--查询2:
select * from sales_par where product = 'CPU';
上例中,查询1的谓词条件包含分区键,因此可以利用分区消除减少扫描的分区数(该例中只需要扫描分区p_2011);而查询2的谓词条件不包含分区键,因此无法利用分区消除。本地分区索引除了分区消除,还具有表可用性更好这个优点,当对某个表分区进行DROP或MERGE操作后,Oracle会自动对所对应的索引分区进行相同的操作,不需要rebuild,即维护操作可以在独立分区进行。
2、全局索引(Global)
全局索引使用GLOBAL关键字创建,索引的分区边界与表的分区边界不一定匹配,且表和索引的分区键也可以不一样。下面是一个全局分区索引的例子:
create index sales_idx2 on sales (year)
global partition by range (year)
( partition p_2010 values less than (2011),
partition p_2012 values less than (2013)
);
在上例中,虽然表和索引的分区键是一样的,但是它们的分区边界不一样,所以属于全局分区索引。下面是全局索引的特征1.全局索引的分区键和分区数和表的分区键和分区数可能都不相同,表和全局索引的分区机制不一样。
2.全局索引可以分区,也可以是不分区索引,全局索引必须是前缀索引,即全局索引的索引列必须是以索引分区键作为其前几列。
3.全局分区索引的索引条目可能指向若干个分区,因此,对于全局分区索引,即使只截断一个分区中的数据,都需要rebulid若干个分区甚至是整个索引。
4.全局索引多应用于OLTP系统中。
5.全局分区索引只按范围或者散列hash分区,hash分区是10g以后才支持。
6.oracle9i以后对分区表做move或者truncate的时可以用update global indexes语句来同步更新全局分区索引,用消耗一定资源来换取高度的可用性。
7.表用a列作分区,索引用b列作为局部分区索引,若where条件中用b来查询,那么oracle会扫描表和索引的所有分区,成本很高高,此时可以考虑用b做全局分区索引。
下面是全局索引的一个示意图:
分享到:
相关推荐
ORACLE 分区表 分区索引 索引分区 实例讲解
总结描述Oracle 11g分区表的种类及分区索引的类型。范围分区,列表分区,散列分区,组合分区,哈希分区,全局索引,分区索引
虽然存储介质和数据处理技术的发展也很快,但是仍然不能满足用户的需求,为了使用户的大量的数据在读写操作和查询中速度更快,Oracle提供了对表和索引进行分区的技术,以改善大型应用系统的性能。
oracle索引与分区索引介绍 删除分区 分区合并(从中间删除掉一个分区,或者两个分区需要合并后减少分区数量) 创建新的分区 交换分区
oracle 分区索引,本地索引,全局索引的区别
对于oracle分区表分区索引的详细说明。 详细描述了分区表的类型,分区索引的类型 分类 。 删除或truncate 表分区时,什么样的情况索引会失效 需要重建 ,什么时候 对索引 没影响 。
如何创建,管理分区,分区索引。
对orcle大数据的查询的优化,ORACLE分区表、分区索引ORACLE对于分区表方式其实就是将表分段存储,一般普通表格是一个段存储,而分区表会分成多个段,所以查找数据过程都是先定位根据查询条件定位分区范围,即数据在...
Oracle分区表和分区索引在VLDB中的研究.pdf
ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区ORACLE分区
局部索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区数,一句话,局部索引的分区机制和表的分区机制一样。2.如果局部索引的索引列以分区键开头,则称为前缀局部索引。3.如果局部索引的列不是以...
深入学习分区表及分区索引(详解oracle分区).docx
Oracle表分区和索引分区 分区概述 为了简化数据库大表的管理,例如在数据仓库中一般都是TB级的数量级.ORACLE8以后推出了分区选项.分区将表分离在若于不同的表空间上,用分而治之的方法来支撑元限膨胀的大表,组...
全面学习分区表及分区索引-Oracle.pdf
分享一个自己学习和实践的关于Oracle表自动按月分区知识点,已经在项目上线并且有效的方案。
oracle分区与索引
本资料是讲解oracle分区表及分区索引技术资料,也许对大家有用.
oracle索引和表分区,oracle索引,oracle表分区
分区索引(或索引分区)主要是针对分区表而言的。随着数据量的不断增长,普通的堆表需要转换到分区表,其索引呢,则对应的转换到分区索引。分区索引的好处是显而易见的。就是简单地把一个索引分成多个片断,在获取所需...