博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle 分区表中索引失效
阅读量:6992 次
发布时间:2019-06-27

本文共 947 字,大约阅读时间需要 3 分钟。

当对分区表进行 一些操作时,会造成索引失效。

 当有truncate/drop/exchange 操作分区  时全局索引 会失效。

exchange 的临时表没有索引,或者

有索引,没有用including indexes的关键字,会导致局部的索引失效,就是某个分区失效
重建局部索引只能用alter index local_idx rebuild partition p1这样的方式

分区表SPLIT的时候,如果MAX区中已经有记录了,这个时候SPLIT就会导致有记录的新增分区的局部索引失效!

 

查寻某个分区表中 各个分区 索引状态  USABLE/UNUSABLE

select index_name, partition_name, status  from user_ind_partitions where index_name = 'indexName';

--重建索引

--local索引重建select b.table_name,a.INDEX_NAME,a.PARTITION_NAME,a.STATUS,'alter index ' || a.index_name || ' rebuild partition ' ||partition_name || ';' 重建列from USER_IND_PARTITIONS a, user_part_indexes bwhere a.index_name = b.index_nameand b.TABLE_NAME IN ('PART_TAB_SPLIT')and STATUS = 'UNUSABLE'ORDER BY b.table_name, a.INDEX_NAME, a.PARTITION_NAME;--全局索引重建 alter index idx_part_split_col3 rebuild;

在针对truncate等 操作时直接更新 index 也可以搞定。 

alter table part_tab_trunc truncate partition p2 Update GLOBAL  indexes;

  

转载于:https://www.cnblogs.com/javaMan/p/3980469.html

你可能感兴趣的文章
sql server存儲過程語法
查看>>
msbuild ignore project dependencies问题
查看>>
Mysql InnoDB锁
查看>>
Google搜索技巧
查看>>
Android210 调试支持 wince6.0系统
查看>>
Android 开发佳站
查看>>
JSR310 时间类型的相互转换
查看>>
Support Vector Machine (2) : Sequential Minimal Optimization
查看>>
过滤器
查看>>
委托和回调函数例子
查看>>
XML与HTML 区别
查看>>
1312:【例3.4】昆虫繁殖(递推算法)
查看>>
继承,多态,抽象,接口
查看>>
C#ADO.NET基础一
查看>>
一个文字横向滚动的JavaScript文档
查看>>
junit整合spring
查看>>
java正则表达式【大全】
查看>>
mac上git安装与github基本使用
查看>>
如何为引用类型如何重写Object.Equals()方法?
查看>>
下拉顶部刷新简单实现
查看>>