Oracle 分區表中索引失效


當對分區表進行 一些操作時,會造成索引失效。

 當有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 b
where a.index_name = b.index_name
and 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;

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM