[Oracle]分区索引
上一节学习了分区表,接着学习分区索引。
(一)什么时候对索引进行分区
· 为了避免移动数据时重建整个索引,可对索引分区,在重建索引时,只需重建与数据分区相关的索引;
· 在对分区表进行维护时,为了避免整个表的索引处于不可用状态,可将索引进行分区。当对分区表进行维护时,只需将该分区表的索引置为不可用状态,并不会影响到其它分区索引的使用;
· 索引表的急剧增长导致索引条目的剧增,使得整个索引表非常大,影响索引速度,需要对索引分区;
(二)本地分区索引
(1)本地分区索引是为分区表中的各个分区创建单独的索引分区,各个索引分区之间是相互独立的,索引的分区与表的分区是一一对应的,一个分区表有几个分区,就有几个本地分区索引。当对本地分区表进行分区的添加、删除、合并等操作时,系统会自动对分区索引进行维护,创建本地分区索引需要使用LOCAL关键字。
图.分区表与本地分区索引一一对应
(2)本地分区索引的优点:
l 如果需要对一个表分区进行维护,则受影响的只是与之关联的索引;
l 重建某个索引分区,其它分区不会受到影响;
l 本地分区索引支持单一分区数据的装入和卸出;
l 本地分区索引采用与分区表相同的分区方法,有利于生成高效的查询计划;
l 本地分区索引简化了表空间的不完全恢复,在恢复分区/子分区的时候同时恢复对应的分区索引。
(3)为分区表创建本地分区索引
CREATE INDEX index_name ON partition_table_name(column) LOCAL;
例子1.为sales_by_list创建分区索引sales_by_index
CREATE INDEX sales_by_index ON sales_by_list(province)
结果如下:
(三)全局分区索引
(1)全局分区索引是对整个表建立索引,然后再对索引进行分区。索引的分区之间不是相互独立的,索引分区与表分区也不是一一对应的关系。Oracle全局分区索引分区方法包括范围分区(Range)和散列分区(Hash),全局分区需要使用GLOBAL关键字。
图.全局索引的4种情况
(2)为分区表创建全局分区索引,主要有2步:创建全局索引和对全局索引进行分区,语法为:
CREATE INDEX index_name ON [partition]_table_name(column) --创建全局索引
GLOBAL PARTITION BY Range(column) --以Range方式为例,对索引表进行分区
(
PARTITION partition VALUES LESS THAN() TABLESPACE tablespace,
…
);
例子2.为sale_by_range创建全局分区索引
/*为sales_by_range表创建全局分区索引*/ create index sale_by_range_index on sale_by_range(time_id)
global partition by range(time_id)
(
partition sales_by_range_index_1 values less than(to_date('2012-1-1','yyyy-mm-dd')),
partition sales_by_range_index_2 values less than(to_date('2012-4-5','yyyy-mm-dd')),
partition sales_by_range_index_3 values less than(maxvalue)
);
结果如下:
(4)维护分区索引
使用ALTER INDEX语句来维护索引分区
(四)查看分区索引的信息
Oracle提供了数据字典来查看分区索引的信息
[Oracle]分区索引的更多相关文章
- 01 Oracle分区索引
Oracle分区索引 索引与表类似,也可以分区: 分区索引分为两类: Locally partitioned index(局部分区索引) Globally partitioned index(全局 ...
- Oracle分区索引
索引与表类似,也可以分区: 分区索引分为两类: Locally partitioned index(局部分区索引) Globally partitioned index(全局分区索引) 下面就来详细解 ...
- oracle 分区和分区索引
一.个人理解:建表时一般都会指定在一个表空间上,但是可能随着表空间扩大,查询越来越慢,分区表就是将一个表实际存在不同的表空间,oracle存储分为块,断,表空间.新建一个表,会给表分配指定大小的段,段 ...
- 深入学习Oracle分区表及分区索引
关于分区表和分区索引(About Partitioned Tables and Indexes)对于10gR2而言,基本上可以分成几类: • Range(范围)分区 • Has ...
- 转:深入学习Oracle分区表及分区索引
转自:http://database.ctocio.com.cn/tips/286/8104286.shtml 关于分区表和分区索引(About Partitioned Tables and Inde ...
- oracle 分区表和分区索引
很复杂的样子,自己都没有看完,以备后用 http://hi.baidu.com/jsshm/item/cbfed8491d3863ee1e19bc3e ORACLE分区表.分区索引ORACLE对于分区 ...
- ORACLE分区表、分区索引详解
详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt160 ORACLE分区表.分区索引ORACLE对于分区表方式其实就是将表分段 ...
- 【三思笔记】 全面学习Oracle分区表及分区索引
[三思笔记]全面学习Oracle分区表及分区索引 2008-04-15 关于分区表和分区索引(About PartitionedTables and Indexes) 对于 10gR2 而言,基本上可 ...
- 简单ORACLE分区表、分区索引
前一段听说CSDN.COM里面很多好东西,同事建议看看合适自己也可以写一写,呵呵,今天第一次开通博客,随便写点东西,就以第一印象分区表简单写第一个吧. ORACLE对于分区表方式其实就是将表分段存储, ...
随机推荐
- 【linux相识相知】VIM编辑器
Vim是一个类似Vi的著名的功能强大.高度可定制的文本编辑器,在Vi的基础上改进和增加了许多的功能,VIM是自由软件,今天我们就来讲讲VIM的使用方法. 本文是基于centos7上的vim编辑器演示的 ...
- 一个C#后台调用接口的例子
string url = ConfigurationSettings.AppSettings["resurl"].ToString(); var wc = new WebClien ...
- Android界面编程--使用活动条(ActionBar)--添加Action View
ActionBar除了显示Action Item 外,还能显示普通的ui组件 2种方式添加Action View 1.指定ActionView的实现类 2.指定ActionView对应的视图资源 实现 ...
- python的返回值
1.返回值的作用 函数并非总是直接显示输出,相反,它可以处理一些数据,并返回一个或一组值.函数返回的值被称为返回值.在函数中,可使用return语句将值返回到调用函数的代码行.返回值让你能够将程序的大 ...
- pythion的定义函数和传递实参
1.定义函数 例子: def greet_user(): """显示简单的问候语""" print("Hello!")g ...
- java selector
java selector使用select轮询注册到selector中的channel,如果有channel准备好注册的事件,select()返回,返回值为可以操作的channel的个数.通过sele ...
- 【Linux】安装Nginx
注:转自https://www.cnblogs.com/hdnav/p/7941165.html 安装所需环境 Nginx 是 C语言 开发,建议在 Linux 上运行,当然,也可以安装 Window ...
- Spring课程 Spring入门篇 5-1 aop基本概念及特点
概念: 1 什么是aop及实现方式 2 aop的基本概念 3 spring中的aop 1 什么是aop及实现方式 1.1 aop,面向切面编程,比如:唐僧取经需要经过81难,多一难少一难都不行.孙悟空 ...
- Html5的map在实际使用中遇到的问题及解决方案
前言:百度了一下html map,嗯嗯,介绍的挺详细的,如果是初学者,直接看他们的教程,挺好的,就不用我再多说了. 不过我发现一个问题,就是都是介绍map有什么属性怎么用的,这明显就是照搬文档自己再改 ...
- web Worker基本使用
web worker 使用 web worker 是现代浏览器具有的可以处理密集型任务非常便利的解决方案,众所周知,JavaScript是单线程的(一个JavaScript引擎实例只能占用一个线程,线 ...