设为首页 收藏本站
查看: 976|回复: 0

[经验分享] [Oracle] Local VS Global 分区索引

[复制链接]

尚未签到

发表于 2016-7-27 11:33:33 | 显示全部楼层 |阅读模式
  在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;


可以看出,创建本地分区索引的语句非常简单,不需要指定分区边界,因为它的分区边界和表的一样。其示意图如下: DSC0000.jpg

  本地分区索引有如下基本特征:
  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做全局分区索引。

  

下面是全局索引的一个示意图:


DSC0001.jpg

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-250249-1-1.html 上篇帖子: Oracle Tkprof(Trace Kernel Profile)工具 下篇帖子: Oracle 11G 虚拟列 Virtual Column介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表