环境:oracle 12.2.0.1

注:未确定10g,11g是否有这些特性。现在基本不用10g,主要用12c,11g。

毫无疑问,这种 特性对于dba或者实施人员而言显得很重要,尤其当你的数据库主要用于olap或者dw(数据仓库)环境的时候。

很多时候,如果需要在一个巨大的表上创建新的索引,例如这个表示一个基站性能数据,可能整张表有3-5亿条。

如果按照以往的操作,明显是非常可怕的事情:

  • 消耗巨量的时间
  • 不一定成功
  • 可能影响业务的进行

然后,有了局部本地分区索引就不一样了。

以下就是本人的试验!

 create table t_tab_columns(
owner varchar2(128) NOT NULL,
table_name varchar2(128) NOT NULL,
column_name varchar2(128) NOT NULL,
data_type varchar2(128),
data_type_mod varchar2(3),
data_type_owner varchar2(128),
data_length number,
data_precision number,
data_scale number,
nullable varchar2(1),
column_id number,
default_length number,
num_distinct number,
collation varchar2(100)
)
partition by list(owner)
(
partition p_sys values ('SYS','SYSTEM') ,
partition p_sys_other values('MDSYS','CTXSYS','DVSYS','WMSYS','LBACSYS') indexing off,
partition p_USERS values ('LZF','EMCUSER')
); ---
INSERT INTO t_tab_columns
select
owner,
table_name,
column_name,
data_type,
data_type_mod,
data_type_owner,
data_length,
data_precision,
data_scale,
nullable,
column_id,
default_length,
num_distinct,
collation
from dba_tab_columns
WHERE OWNER IN ('SYS','SYSTEM','MDSYS','CTXSYS','DVSYS','WMSYS','LBACSYS','LZF','EMCUSER');
commit;
---2.1创建索引
create index idx_Tab_columns_colname on t_tab_columns(column_name) local indexing partial
--验证
select segment_name,partition_name from user_segments where segment_name='IDX_TAB_COLUMNS_COLNAME';
SEGMENT_NAME PARTITION_NAME
IDX_TAB_COLUMNS_COLNAME P_SYS
IDX_TAB_COLUMNS_COLNAME P_USERS
--**** 证明:有起到作用
--2.2 创建索引而不带 indexing partial
create index idx_Tab_columns_dt on t_tab_columns(data_type) local ;
--验证
select segment_name,partition_name from user_segments where segment_name='IDX_TAB_COLUMNS_DT';
SEGMENT_NAME PARTITION_NAME
IDX_TAB_COLUMNS_DT P_SYS
IDX_TAB_COLUMNS_DT P_SYS_OTHER
IDX_TAB_COLUMNS_DT P_USERS
--**** 证明:是否创建索引完全取决于 indexing partial 字句。
--2.3 如果把本来可以索引的,调整为不可索引,会如何了?
alter table t_tab_columns modify partition p_users indexing off;
--验证
select segment_name,partition_name from user_segments where segment_name='IDX_TAB_COLUMNS_COLNAME';
SEGMENT_NAME PARTITION_NAME
IDX_TAB_COLUMNS_COLNAME P_SYS select segment_name,partition_name from user_segments where segment_name='IDX_TAB_COLUMNS_DT';
SEGMENT_NAME PARTITION_NAME
IDX_TAB_COLUMNS_DT P_SYS
IDX_TAB_COLUMNS_DT P_SYS_OTHER
IDX_TAB_COLUMNS_DT P_USERS
--**** 证明:只影响采用了 indexing partial的索引,会删除对应分区的索引。 --2.4 如果把本来不可以索引的,调整为可索引,会如何了?
alter table t_tab_columns modify partition p_users indexing on;
--验证
select segment_name,partition_name from user_segments where segment_name='IDX_TAB_COLUMNS_COLNAME';
SEGMENT_NAME PARTITION_NAME
IDX_TAB_COLUMNS_COLNAME P_SYS
IDX_TAB_COLUMNS_COLNAME P_USERS
select segment_name,partition_name from user_segments where segment_name='IDX_TAB_COLUMNS_DT';
结果略。
--**** 证明:修改表分区的indexing属性,只影响采用了 indexing partial的索引,会重建对应分区的索引。

通过修改所有分区的indexing 属性(为off),然后创建indexing partial对的本地索引,最后通过一个定时任务把对应分区修改为indexing on,就可以逐步创建每个分区的索引。

oracle的局部本地分区索引的更多相关文章

  1. Oracle非分区索引,全局分区索引和本地分区索引。

    1.如果按照索引是否分区作为划分依据,Oracle 的索引类型可以分为非分区索引,全局分区索引和本地分区索引. 2.创建演示实例 --创建非分区表create table test_partition ...

  2. [Oracle]分区索引

    上一节学习了分区表,接着学习分区索引. (一)什么时候对索引进行分区 · 为了避免移动数据时重建整个索引,可对索引分区,在重建索引时,只需重建与数据分区相关的索引: · 在对分区表进行维护时,为了避免 ...

  3. PLSQL_Oracle分区表和相应的分区索引管理和使用(案例)

    2014-08-22 Created By BaoXinjian

  4. Oracle 学习总结 - 表和索引的性能优化

    表的性能 表的性能取决于创建表之前所应用的数据库特性,数据库->表空间->表,创建数据库时确保为每个用户创建一个默认的永久表空间和临时表空间并使用本地管理,创建表空间设为本地管理并且自动段 ...

  5. Atitit.分区对索引的影响 分区索引和全局索引 attilax总结

    Atitit.分区对索引的影响 分区索引和全局索引 attilax总结 1. 分区的好处1 2. 分区键:2 3. 分区的建议:2 4. 分区索引和全局索引:2 5. 全局索引就是在全表上创建索引, ...

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

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

  7. Oracle分区索引

    索引与表类似,也可以分区: 分区索引分为两类: Locally partitioned index(局部分区索引) Globally partitioned index(全局分区索引) 下面就来详细解 ...

  8. 转:深入学习Oracle分区表及分区索引

    转自:http://database.ctocio.com.cn/tips/286/8104286.shtml 关于分区表和分区索引(About Partitioned Tables and Inde ...

  9. oracle 分区和分区索引

    一.个人理解:建表时一般都会指定在一个表空间上,但是可能随着表空间扩大,查询越来越慢,分区表就是将一个表实际存在不同的表空间,oracle存储分为块,断,表空间.新建一个表,会给表分配指定大小的段,段 ...

随机推荐

  1. vue——指令系统

    指令系统,可以联想咱们的cmd命令行工具,只要我输入一条正确的指令,系统就开始干活了. 在vue中,指令系统,设置一些命令之后,来操作我们的数据属性,并展示到我们的DOM上. 在vue中提供了一套为数 ...

  2. 【数据库】5.0 MySQL入门学习(五)——MySQL源码了解及MySQL初始化设置

    1.0 MySQL源码目录主要包括:客户端代码.服务端代码.测试工具.其他库文件.当然,看懂源代码得有一定的C语言基础. BUILD:各种平台的编译脚本,可以用来制作各平台的二进制版本 client: ...

  3. pdf转为html查看pdf.js

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. Linux自有服务

    Linux自有服务 Linux自带的功能:运行模式.用户和用户组管理.网络配置.ssh服务 1.运行模式 Linux下的初始化进程:init,进程id为1 该进程的配置文件:/etc/inittab ...

  5. 基于ArcGIS Runtime 100.x 的移动应用程序开发框架 开源

    ArcGIS Runtime作为新一代的轻量GIS应用开发产品,它提供多种API,可以使用Android,iOS,Java,Mac OS X(Objective-C/Swift)..NET,Qt(C+ ...

  6. Qt之QSS(样式表语法)

    http://blog.csdn.net/liang19890820/article/details/51691212 版权声明:进步始于交流,收获源于分享!纯正开源之美,有趣.好玩.靠谱...作者: ...

  7. jdk时区相差8小时

    设置JVM的默认时区为东八区(北京时间)在下面四个目录(jre6\lib\zi\Etc.jre6\lib\zi.jdk1.6.0_18\jre\lib\zi\Etc.jdk1.6.0_18\jre\l ...

  8. Ruby系列文章之1---开发者应该熟悉的10个工具

    1. Git Git是进入Ruby这个生态圈首先最应该学会的工具.几乎所有以Ruby开发出来的套件都放在Github上.也就是不管你要下载或修改协作都需要透过Git. 2. RVM Ruby有很多种i ...

  9. 【java开发系列】—— 嵌套类与内部类

    嵌套类与内部类在java中使用的很广泛,为了避免难以理解,这里用了几个小例子,说明它的用法. 嵌套类与内部类的结构如下图 静态嵌套类 静态嵌套类,是一种在类之外声明的嵌套类,由于是静态的,所以不经过初 ...

  10. 【Spring实战】—— 11 通过AOP为特定的类引入新的功能

    如果有这样一个需求,为一个已知的API添加一个新的功能. 由于是已知的API,我们不能修改其类,只能通过外部包装.但是如果通过之前的AOP前置或后置通知,又不太合理,最简单的办法就是实现某个我们自定义 ...