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

局部索引local index
1.局部索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区数,一句话,局部索引的分区机制和表的分区机制一样。
2.如果局部索引的索引列以分区键开头,则称为前缀局部索引。
3.如果局部索引的列不是以分区键开头,或者不包含分区键列,则称为非前缀索引。
4.局部索引只能依附于分区表上。
5.前缀和非前缀索引都可以支持索引分区消除,前提是查询的条件中包含索引分区键。
6.局部索引只支持分区内的唯一性,无法支持表上的唯一性,因此如果要用局部索引去给表做唯一性约束,则约束中必须要包括分区键列。
7.局部分区索引是对单个分区的,每个分区索引只指向一个表分区;全局索引则不然,一个分区索引能指向n个表分区,同时,一个表分区,也可能指向n个索引分区,对分区表中的某个分区做truncate或者move,shrink等,可能会影响到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、建分区表 
CREATE TABLE P_TAB( 
C1 INT, 
C2 VARCHAR2(16), 
C3 VARCHAR2(64), 
C4 INT , 
CONSTRAINT PK_PT 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) 
); 
--2、建全局分区索引 
CREATE INDEX IDX_PT_C4 ON P_TAB(C4) GLOBAL PARTITION BY RANGE(C4) 

PARTITION IP1 VALUES LESS THAN(10000), 
PARTITION IP2 VALUES LESS THAN(20000), 
PARTITION IP3 VALUES LESS THAN(MAXVALUE) 
); 
--3、建本地分区索引 
CREATE INDEX IDX_PT_C2 ON P_TAB(C2) LOCAL (PARTITION P1,PARTITION P2,PARTITION P3,PARTITION P4); 
--4、建全局分区索引(与分区表分区规则相同的列上) 
CREATE INDEX IDX_PT_C1 
ON P_TAB(C1) 
GLOBAL PARTITION BY RANGE (C1) 

PARTITION IP01 VALUES LESS THAN (10000000), 
PARTITION IP02 VALUES LESS THAN (20000000), 
PARTITION IP03 VALUES LESS THAN (30000000), 
PARTITION IP04 VALUES LESS THAN (MAXVALUE) 
); 
--5、分区索引数据字典查看 
SELECT * FROM USER_IND_PARTITIONS; 
SELECT * FROM USER_PART_INDEXES; 
  1. create table computers
  2. comNo number(4)  constraint PK_comp primary key,
  3. compModel varchar2(64) constraint unique_comp unique,
  4. buyTime date,
  5. price number(12,2) constraint ch_price check(
  6. price>0 and price<=300000),
  7. owner varchar2(32));
  8. DECLARE
  9. i number := 0;
  10. BEGIN
  11. for i in 1 .. 3000 loop
  12. insert into computers
  13. (comNo, compModel, buyTime, price, owner)
  14. values
  15. (i, '8' + i, to_date('' + sysdate, 'YYYY-MM'), i, 'zhangsan');
  16. --dbms_output.put_line(i);
  17. end loop;
  18. commit;
  19. END;

P_TAB

oracle分区索引及循环插入相关推荐

  1. 如何获得Oracle分区索引类型

    碰巧在墨天轮上看资料就看到了eygle的这篇文章<如何获得 Oracle 分区索引的类型 - 全局分区索引.本地分区索引>,秉承了eygle大神一如既往的风格,文章"短小&quo ...

  2. oracle全局索引 效率,关于插入,全局索引和局部索引的情况,那种效率高

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

  3. oracle全局索引改成本地索引,FAQ : 如何获得 Oracle 分区索引的类型 - 全局分区索引、本地分区索引...

    Oracle 数据库针对分区的信息,通过多个数据字典视图来维护,所以在获取信息时,经常会困惑 DBA 们. 例如,如何获取 分区索引的类型,如何判断一个索引,是 全局分区索引,还是本地分区索引? 通过 ...

  4. Oracle 分区索引详解(local、global)

    文章目录 1 概述 2 分区索引 2.1 本地分区索引 2.2 全局分区索引 2.3 索引查询 3 扩展 3.1 表分区 1 概述 #mermaid-svg-sGSwuCo7gqIZ05IC {fon ...

  5. 关于 Oracle 分区索引的失效和重建

    --创建测试表 SQL> create table t as select object_id,object_name from dba_objects; 表已创建. SQL> selec ...

  6. Oracle分区表及分区索引

    Oracle分区索引 索引与表类似,也可以分区: 分区索引分为两类: Locally partitioned index(局部分区索引) Globally partitioned index(全局分区 ...

  7. Oracle之表分区、分区索引(二)

    其实range分区你学会了,其他的分区你也学会了,在这我就不敲了,咱们简单来看一下,hash分区,hash分区实现负载均衡,平均分配值进行分区,那这个哈希就是平均分配的,也是一张表,还是partiti ...

  8. Oracle之表分区、分区索引(一)

    继续往下讲就是分区了 对于ORACLE来讲,分区是咱们开发中最常用的,什么样的场景下要进行分区,主要是针对于大数据量的表,频繁查询的表,我只是说数据量大的表,并没有说物理的这个大,比如你搞一个文件表, ...

  9. 深入学习Oracle分区表及分区索引

    关于分区表和分区索引(About Partitioned Tables and Indexes)对于10gR2而言,基本上可以分成几类: ?       Range(范围)分区 ?       Has ...

最新文章

  1. 设置IDEA最多同时打开的窗口数量为100
  2. 报告:最大化人工智能(AI)机遇
  3. 中山计算机编程,中山plc编程设计
  4. 计算机操作系统:存储器的管理
  5. 「数据库系列三」磁盘、内存和带宽
  6. python中的对象列表_Python内建的对象列表
  7. Object-C中方法
  8. fastreport dll_报表如何连接到VistaDB嵌入式数据库?FastReport.Net轻松搞定
  9. php腾讯云+视频上传失败,腾讯云视频上传和播放尝试总结
  10. linux dns chroot,chroot DNS 过程(包括一些简单的排错过程)
  11. webpack打包后引用cdn的js_手摸手 Webpack 多入口配置实践
  12. 素数类型C语言题目总结
  13. 预算分配Budget Allocation:Morphl-AI的营销科学解决方案(一)
  14. idea导出Oracle表结构和数据
  15. SpringBoot+Vue+Cas单点登录与登出
  16. freeswitch添加G729编解码模块
  17. QGC使用国内天地图卫星图并添加注记图层
  18. BIOS实战之Super IO-Smart Fan
  19. 西门子行贿门情报列表,我自己写的一个小软件自动搜集到的。
  20. perl 大小写转化

热门文章

  1. 《MySQL——38道查询练习(无连接查询)》
  2. COLLEGE.sql(复制的时候注意路径!!!)
  3. SDP协议基本分析(RTSP、WebRTC使用)
  4. ffmpeg进行混音,将两路音频pcm数据合成一路输出
  5. 郓城天气预报软件测试,郓城天气预报15天
  6. java对接华为推送服务_华为HMS Core 4.0版本即将来袭:包含新推送服务
  7. 指针与零的比较以及浮点型与零的比较
  8. linux网络编程函数——地址复用setsockopt()
  9. 记录一下自己的VScode插件
  10. 安卓开发必须会的技能!浅谈Android消息机制原理,威力加强版