`

分区表、分区索引和全局索引部分总结

 
阅读更多

分区表、分区索引和全局索引:

 

  在一个表的数据超过过2000万条或占用2G空间时,建议建立分区表。

 

      create table ta(c1 int,c2 varchar2(16),c3 varchar2(64),c4 int constraint pk_ta 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));

  

  分区索引和全局索引:

 

  分区索引就是在所有每个区上单独创建索引,它能自动维护,在drop或truncate某个分区时不影响该索引的其他分区索引的使用,也就是索引不会失效,维护起来比较方便,但是在查询性能稍微有点影响。

 

      create index idx_ta_c2 on ta(c2) local (partition p1,partition p2,partition p3,partition p4); 或者 create index idx_ta_c2 on ta(c2) local ;

 

   另外在create unique index idx_ta_c2 on ta(c2) local ;系统会报ORA-14039错误,这是因为ta表的分区列是c1,oracle不支持在分区表上创建PK主键时主键列不包含分区列,创建另外的约束(unique)也不可以。

 

  全局索引就是在全表上创建索引,它可以创建自己的分区,可以和分区表的分区不一样,也就是它是独立的索引。在drop或truncate某个分区时需要创建索引alter index idx_xx rebuild,也可以alter table table_name drop partition partition_name update global indexes;实现,但是要花很长时间在重建索引上。可以通过查询user_indexes、user_part_indexes和user_ind_partitions视图来查看索引是否有效。

 

      create index idx_ta_c3 on ta(c3);

  

  或者把全局索引分成多个区(注意和分区表的分区不一样):

 

      create index idx_ta_c4 on ta(c4) global partition by range(c4)(partition ip1 values less than(10000),partition ip2 values less than(20000),partition ip3 values less than(maxvalue));

  

  注意索引上的引导列要和range后列一致,否则会有ORA-14038错误。

  oracle会对主键自动创建全局索引

  如果想在主键的列上创建分区索引,除非主键包括分区键,还有就是主键建在两个或以上列上。

  在频繁删除表的分区且数据更新比较频繁时为了维护方便避免使用全局索引。

 

  ----------------------------------------------------------------------

 

 局部索引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做全局分区索引

分享到:
评论

相关推荐

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

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

    Oracle分区表及分区索引

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

    深入oracle分区索引的详解

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

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

    分区索引(或索引分区)主要是针对分区表而言的。随着数据量的不断增长,普通的堆表...b、分区索引可以分为本地分区索引以及全局分区索引 本地分区索引:  本地分区索引信息的存放依赖于父表分区。也就是说对于本地索

    ORACLE重建索引总结

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

    oracle使用索引与不使用索引的性能详析

    前言 Oracle存储索引的数据结构是B*树。位图索引也是如此,仅仅只是是叶子节点不同B*数索引; 索引由根节点、分支节点和叶子节点组成。上级索引块包括下级... 全局有前缀分区索引 散列分区索引 基于函数的索引 ora

    数据RAC11g 升级到 RAC 19c

    特别要求:数据库内必须有一个表的数据量超过5千万,并有三个复合索引,一个表数据量超过1亿,并且是分区表,并包含三个全局索引。2、(重点)用一个或者多个并发的程序或者代码,不停的对数据库有DML操作,就是...

    关系型数据库性能体系设计和效率提升.docx

    4.2.1 不使用全局索引 12 4.2.2 RANGE分区的规范 12 4.2.3 LIST分区的规范 13 4.2.4 HASH分区的规范 13 4.2.5 RANGE-LIST分区的规范 14 4.2.6 RANGE-HASH分区的规范 14 5 索引的设计规范 15 5.1 索引分类 15 5.1.1...

    Oracle数据文件收缩实例.doc

    Oracle的全局索引也存储在dba_segments中,并以index标志,而且其重建方式跟普通索引一致,所以在执行忘回导入的时候需要按照move 普通表;move分区表;move全局索引;move分区索引;move lob对象的顺序进行。

    PostegreSQL-partitioning

    编写查询:插入数据,添加和删除分区,创建全局索引和局部索引,以获取数据并使用索引 要提交工作,您需要提供指向git存储库的链接,该链接包含: 自然语言书面查询 PostgreSQL内置了对以下类型分区的支持: 按...

    oracle学习经典教程

    1.3 分区表总结.............41 1.3.1. 分区表理论知识........................41 1.3.2 普通表转分区表方法..................45 1.3.2.1 插入: Insert with a subquery method ..........................

    SQL Server 2008管理员必备指南(超高清PDF)Part1

    10.9 创建已分区表和索引 10.9.1 创建分区函数 10.9.2 创建分区方案 10.9.3 创建分区 10.9.4 查看和管理分区 10.10 压缩表、索引和分区 10.10.1 使用行和页压缩 10.10.2 设置或改变压缩设置 第11章 数据的导入和...

    SQL Server 2008管理员必备指南(超高清PDF)Part3

    10.9 创建已分区表和索引 10.9.1 创建分区函数 10.9.2 创建分区方案 10.9.3 创建分区 10.9.4 查看和管理分区 10.10 压缩表、索引和分区 10.10.1 使用行和页压缩 10.10.2 设置或改变压缩设置 第11章 数据的导入和...

    SQL Server 2008管理员必备指南(超高清PDF)Part2

    10.9 创建已分区表和索引 10.9.1 创建分区函数 10.9.2 创建分区方案 10.9.3 创建分区 10.9.4 查看和管理分区 10.10 压缩表、索引和分区 10.10.1 使用行和页压缩 10.10.2 设置或改变压缩设置 第11章 数据的导入和...

    分布式数据库设计方案.doc

    当数据量很大的时候,对数据库的装载与导 出,备份与恢复,结构的调整,索引的调整等都会让数据库停止服务或者高负荷运转很 长时间,影响数据库的可用性和易管理性。 分区表技术 让用户能够把数据分散存放到不同的...

    Oracle 9i&10g编程艺术:深入数据库体系结构(全本)含脚本

    13.3.1 局部索引与全局索引 587 13.3.2 局部索引 587 13.3.3 全局索引 594 13.4 再论分区和性能 610 13.5 审计和段空间压缩 617 13.6 小结 618 第14章 并行执行 619 14.1 何时使用并行执行 620 14.2 并行...

    收获不止SQL优化

    7.3.1 分区表相关案例 185 7.3.2 全局临时表案例 190 7.3.3 监控异常的表设计 195 7.3.4 表设计优化相关案例总结 199 7.4 本章习题、总结与延伸 199 第8章 且慢,学习索引如何让SQL飞 200 8.1 索引知识要点...

    收获,不止SQL优化--抓住SQL的本质

    7.3.1 分区表相关案例 185 7.3.2 全局临时表案例 190 7.3.3 监控异常的表设计 195 7.3.4 表设计优化相关案例总结 199 7.4 本章习题、总结与延伸 199 第8章 且慢,学习索引如何让SQL飞 200 8.1 索引知识要点...

    SQL.Server.2008管理员必备指南.part2.rar(2/4)

     操作架构、表、索引和视图  进行自动化维护和实现基于策略的管理  监视服务器活动并优化性能  管理日志传送和数据库镜像  执行备份和还原  《微软技术丛书》包括以下几个子系列  从入门到精通  适舍新手...

    SQL.Server.2008管理员必备指南.part1.rar(1/4)

     操作架构、表、索引和视图  进行自动化维护和实现基于策略的管理  监视服务器活动并优化性能  管理日志传送和数据库镜像  执行备份和还原  《微软技术丛书》包括以下几个子系列  从入门到精通  适舍新手...

Global site tag (gtag.js) - Google Analytics