深入oracle分区索引的详解
PARTITION P2 VALUES LESS THAN (20000000),
C1 INT,
5.前缀和非前缀索引都可以支持索引分区消除,前提是查询的条件中包含索引分区键。
C3 VARCHAR2(64),
C2 VARCHAR2(16),
PARTITION P1 VALUES LESS THAN (10000000),
5.全局索引多应用于oltp系统中。
PARTITION IP2 VALUES LESS THAN(20000),
--3、建本地分区索引
);
PARTITION BY RANGE(C1)(
--1、建分区表
C4 INT ,
分区索引实例
(
SELECT * FROM USER_IND_PARTITIONS;
1.局部索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区数,一句话,局部索引的分区机制和表的分区机制一样。
分区索引字典
PARTITION IP02 VALUES LESS THAN (20000000),
3.如果局部索引的列不是以分区键开头,或者不包含分区键列,则称为非前缀索引。
4.全局分区索引的索引条目可能指向若干个分区,因此,对于全局分区索引,即使只截断一个分区中的数据,都需要rebulid若干个分区甚至是整个索引。
复制代码 代码如下:
PARTITION P3 VALUES LESS THAN (30000000),7.局部分区索引是对单个分区的,每个分区索引只指向一个表分区;全局索引则不然,一个分区索引能指向n个表分区,同时,一个表分区,也可能指向n个索引分区,对分区表中的某个分区做truncate或者move,shrink等,可能会影响到n个全局索引分区,正因为这点,局部分区索引具有更高的可用性。
7.oracle9i以后对分区表做move或者truncate的时可以用update global indexes语句来同步更新全局分区索引,用消耗一定资源来换取高度的可用性。
PARTITION IP3 VALUES LESS THAN(MAXVALUE)
Dba_ind_partitions 每个分区索引的分区级统计信息
6.全局分区索引只按范围或者散列分区,hash分区是10g以后才支持。
CREATE INDEX IDX_PT_C4 ON P_TAB(C4) GLOBAL PARTITION BY RANGE(C4)
--2、建全局分区索引
1.全局索引的分区键和分区数和表的分区键和分区数可能都不相同,表和全局索引的分区机制不一样。
需要对每个分区索引做rebuild,重建的时候可以选择online(不会锁定表),或者nologging建立索引的时候不生成日志,加快速度。
2.全局索引可以分区,也可以是不分区索引,全局索引必须是前缀索引,即全局索引的索引列必须是以索引分区键作为其前几列。
GLOBAL PARTITION BY RANGE (C1)
对非分区索引,只能整个index重建
PARTITION IP03 VALUES LESS THAN (30000000),
8.位图索引只能为局部分区索引。
DBA_PART_INDEXES 分区索引的概要统计信息,可以得知每个表上有哪些分区索引,分区索引的类型(local/global)
SELECT * FROM USER_PART_INDEXES;
CREATE INDEX IDX_PT_C1
Alter index rebuild idx_name [online nologging]
9.局部索引多应用于数据仓库环境中。
PARTITION IP04 VALUES LESS THAN (MAXVALUE)
--4、建全局分区索引(与分区表分区规则相同的列上)
(
PARTITION IP1 VALUES LESS THAN(10000),
);
CREATE INDEX IDX_PT_C2 ON P_TAB(C2) LOCAL (PARTITION P1,PARTITION P2,PARTITION P3,PARTITION P4);
);
8.表用a列作分区,索引用b做局部分区索引,若where条件中用b来查询,那么oracle会扫描所有的表和索引的分区,成本会比分区更高,此时可以考虑用b做全局分区索引。
PARTITION P4 VALUES LESS THAN (MAXVALUE)
CREATE TABLE P_TAB(
Alter index idx_name rebuild partition index_partition_name [online nologging]
4.局部索引只能依附于分区表上。
ON P_TAB(C1)
全局索引global index
CONSTRAINT PK_PT PRIMARY KEY (C1)
索引重建
局部索引local index
表可以按range、hash、list分区,表分区后,其上的索引和普通表上的索引有所不同,oracle对于分区表上的索引分为2类,即局部索引和全局索引,下面分别对这2种索引的特点和局限性做个总结。
6.局部索引只支持分区内的唯一性,无法支持表上的唯一性,因此如果要用局部索引去给表做唯一性约束,则约束中必须要包括分区键列。
3.全局索引可以依附于分区表;也可以依附于非分区表。
)
--5、分区索引数据字典查看
PARTITION IP01 VALUES LESS THAN (10000000),
Dba_indexes/dba_part_indexes 可以得到每个表上有哪些非分区索引
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://www.juheyunku.com/sql/oracle/4042.shtml
相关文章
热门TAG
命令 外链 企业网站 白帽 php 织梦教程 dedecms修改内容 javascript 织梦 功能 标签 调用 详解 技巧 权重 服务器 网站流量 Dedecms 织梦cms HTML tags标签 python jquery教程 jquery windows 蜘蛛 搜索引擎 网站收录 JSP 实例解析最新文章
-
OracleRAC的五大优势及其劣
时间:2021-01-05
-
Oracle优化器 自适应执行计
时间:2021-01-05
-
Oracle行内链接不会引起U
时间:2021-01-05
-
Window下Oracle Database 11g 发行
时间:2020-12-29
-
Oracle如何实现like多个值的
时间:2020-12-29
-
maven添加oracle依赖失败问题
时间:2020-12-29
-
OracleRAC基本概念及入门
时间:2020-12-29
-
Azure File Storage 基本用法
时间:2020-12-26
热门文章
-
Azure Queue Storage 基本用法 Azure Storage 之
时间:2020-12-26
-
Oracle存储过程编程详解
时间:2020-12-07
-
win10下oracle 11g安装图文教程
时间:2020-12-25
-
oracle 数据库学习 基本结构介绍
时间:2020-12-13
-
Azure File Storage 基本用法 Azure Storage 之 F
时间:2020-12-26
-
windows使用sqlpus连接oracle 数据库的教程图
时间:2020-12-25
-
Window下Oracle Database 11g 发行版2安装教程
时间:2020-12-29
-
Oracle解锁的方式介绍
时间:2020-12-14
-
linux下oracle设置开机自启动实现方法
时间:2020-12-13
-
Oracle学习记录之使用自定义函数和触发器
时间:2020-12-07
