oracle分区索引及循环插入
表可以按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;
- create table computers
- (
- comNo number(4) constraint PK_comp primary key,
- compModel varchar2(64) constraint unique_comp unique,
- buyTime date,
- price number(12,2) constraint ch_price check(
- price>0 and price<=300000),
- owner varchar2(32));
- DECLARE
- i number := 0;
- BEGIN
- for i in 1 .. 3000 loop
- insert into computers
- (comNo, compModel, buyTime, price, owner)
- values
- (i, '8' + i, to_date('' + sysdate, 'YYYY-MM'), i, 'zhangsan');
- --dbms_output.put_line(i);
- end loop;
- commit;
- END;
P_TAB
oracle分区索引及循环插入相关推荐
- 如何获得Oracle分区索引类型
碰巧在墨天轮上看资料就看到了eygle的这篇文章<如何获得 Oracle 分区索引的类型 - 全局分区索引.本地分区索引>,秉承了eygle大神一如既往的风格,文章"短小&quo ...
- oracle全局索引 效率,关于插入,全局索引和局部索引的情况,那种效率高
分区表上的索引 表可以按range,hash,list分区,表分区后,其上的索引和普通表上的索引有所不同,oracle对于分区表上的索引分为2类,即局部索引和全局索引,下面分别对这2种索引的特点和局限 ...
- oracle全局索引改成本地索引,FAQ : 如何获得 Oracle 分区索引的类型 - 全局分区索引、本地分区索引...
Oracle 数据库针对分区的信息,通过多个数据字典视图来维护,所以在获取信息时,经常会困惑 DBA 们. 例如,如何获取 分区索引的类型,如何判断一个索引,是 全局分区索引,还是本地分区索引? 通过 ...
- Oracle 分区索引详解(local、global)
文章目录 1 概述 2 分区索引 2.1 本地分区索引 2.2 全局分区索引 2.3 索引查询 3 扩展 3.1 表分区 1 概述 #mermaid-svg-sGSwuCo7gqIZ05IC {fon ...
- 关于 Oracle 分区索引的失效和重建
--创建测试表 SQL> create table t as select object_id,object_name from dba_objects; 表已创建. SQL> selec ...
- Oracle分区表及分区索引
Oracle分区索引 索引与表类似,也可以分区: 分区索引分为两类: Locally partitioned index(局部分区索引) Globally partitioned index(全局分区 ...
- Oracle之表分区、分区索引(二)
其实range分区你学会了,其他的分区你也学会了,在这我就不敲了,咱们简单来看一下,hash分区,hash分区实现负载均衡,平均分配值进行分区,那这个哈希就是平均分配的,也是一张表,还是partiti ...
- Oracle之表分区、分区索引(一)
继续往下讲就是分区了 对于ORACLE来讲,分区是咱们开发中最常用的,什么样的场景下要进行分区,主要是针对于大数据量的表,频繁查询的表,我只是说数据量大的表,并没有说物理的这个大,比如你搞一个文件表, ...
- 深入学习Oracle分区表及分区索引
关于分区表和分区索引(About Partitioned Tables and Indexes)对于10gR2而言,基本上可以分成几类: ? Range(范围)分区 ? Has ...
最新文章
- 设置IDEA最多同时打开的窗口数量为100
- 报告:最大化人工智能(AI)机遇
- 中山计算机编程,中山plc编程设计
- 计算机操作系统:存储器的管理
- 「数据库系列三」磁盘、内存和带宽
- python中的对象列表_Python内建的对象列表
- Object-C中方法
- fastreport dll_报表如何连接到VistaDB嵌入式数据库?FastReport.Net轻松搞定
- php腾讯云+视频上传失败,腾讯云视频上传和播放尝试总结
- linux dns chroot,chroot DNS 过程(包括一些简单的排错过程)
- webpack打包后引用cdn的js_手摸手 Webpack 多入口配置实践
- 素数类型C语言题目总结
- 预算分配Budget Allocation:Morphl-AI的营销科学解决方案(一)
- idea导出Oracle表结构和数据
- SpringBoot+Vue+Cas单点登录与登出
- freeswitch添加G729编解码模块
- QGC使用国内天地图卫星图并添加注记图层
- BIOS实战之Super IO-Smart Fan
- 西门子行贿门情报列表,我自己写的一个小软件自动搜集到的。
- perl 大小写转化
热门文章
- 《MySQL——38道查询练习(无连接查询)》
- COLLEGE.sql(复制的时候注意路径!!!)
- SDP协议基本分析(RTSP、WebRTC使用)
- ffmpeg进行混音,将两路音频pcm数据合成一路输出
- 郓城天气预报软件测试,郓城天气预报15天
- java对接华为推送服务_华为HMS Core 4.0版本即将来袭:包含新推送服务
- 指针与零的比较以及浮点型与零的比较
- linux网络编程函数——地址复用setsockopt()
- 记录一下自己的VScode插件
- 安卓开发必须会的技能!浅谈Android消息机制原理,威力加强版