Oracle查看索引狀態及索引重建


目錄
1,查詢索引狀態
  1.1 查詢user_indexes表
  1.2 查詢分區索引-user_ind_partitions表
  1.3 檢查損壞索引
2,索引重建
  2.1全局索引重建
  2.2 local索引重建

1,查詢索引狀態
1.1 查詢user_indexes表
select status,T.* from user_indexes T where table_name='表名'
狀態列STATUS說明:
valid:當前索引有效
N/A :分區索引 有效
unusable:索引失效

1.2 查詢分區索引-user_ind_partitions表
select index_name, partition_name, status
  from user_ind_partitions
 where index_name = '索引名稱';

索引狀態說明:
     USABLE:索引有效
     UNUSABLE:索引失效

1.3 檢查損壞索引
SELECT status, COUNT(*)
     FROM dba_indexes
     GROUP BY status
UNION
SELECT status, COUNT(*)
     FROM dba_ind_partitions
     GROUP BY status
UNION
SELECT status, COUNT(*)
    FROM dba_ind_subpartitions
    GROUP BY status

2,索引重建
2.1全局索引重建
alter index pk_kc03 rebuild nologging;
or
alter index pk_kc03 rebuild

2.2 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;

在針對truncate等 操作時直接更新 index 也可以搞定。
alter table part_tab_trunc truncate partition p2 Update GLOBAL  indexes;


免責聲明!

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



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