oracle怎么查看索引失效

方法:1、利用“select status from user_indexes where index_name='索引名称'”语句,若结果返回VALID,则索引没有失效;2、利用“select status from DBA_IND_PARTITIONS”语句查看分区索引状态;3、利用“select status from dba_indexes”查看普通索引状态。

oracle查看索引

1、打开PLSQL,输入账号密码,登陆需要判断索引状态的数据库。打开SQL窗口,输入如下SQL

1

select status from user_indexes where index_name='索引名称'

如果返回结果为VALID,则表示索引有效!

03.png

2、在相应用户下执行一下语句:

1

select status from DBA_IND_PARTITIONS   --分区索引

如果状态不是VALID的,那么就是失效的索引。

3、在相应用户下执行一下语句

1

select status from dba_indexes  --普通索引

如果状态不是VALID的,那么就是失效的索引。

扩展:

ORACLE查看某个表的索引状态

06.png

状态列STATUS说明:

valid:当前索引有效

N/A :分区索引 有效

unusable:索引失效

在Oracle数据库中,哪些操作会导致索引失效?

Q

题目

在Oracle数据库中,哪些操作会导致索引失效?

A

答案

当某些操作导致数据行的ROWID改变,索引就会完全失效。可以分普通表和分区表来讨论哪些操作将导致索引失效。

(一)普通表索引失效的情形如下所示:

① 手动置索引无效:ALTER INDEX IND_OBJECT_ID UNUSABLE;。

② 如果对表进行MOVE操作(包含移动表空间和压缩操作)或在线重定义表后,那么该表上所有的索引状态会变为UNUSABLE。MOVE操作的SQL语句为:ALTER TABLE TT MOVE;。

③ SQL*Loader加载数据。

在SQL*Loader加载过程中会维护索引,由于数据量比较大,在SQL*Loader加载过程中出现异常情况,也会导致Oracle来不及维护索引,导致索引处于失效状态,影响查询和加载。异常情况主要有:在加载过程中杀掉SQL*Loader进程、重启或表空间不足等。

(二)分区表索引失效的情形如下所示:

① 对分区表的某个含有数据的分区执行了TRUNCATE、DROP操作可以导致该分区表的全局索引失效,而分区索引依然有效,如果操作的分区没有数据,那么不会影响索引的状态。需要注意的是,对分区表的ADD操作对分区索引和全局索引没有影响。

② 执行EXCHANGE操作后,全局索引和分区索引都无条件地会被置为UNUSABLE(无论分区是否含有数据)。但是,若包含INCLUDING INDEXES子句(缺省情况下为EXCLUDING INDEXES),则全局索引会失效,而分区索引依然有效。

③ 如果执行SPLIT的目标分区含有数据,那么在执行SPLIT操作后,全局索引和分区索引都会被被置为UNUSABLE。如果执行SPLIT的目标分区没有数据,那么不会影响索引的状态。

④ 对分区表执行MOVE操作后,全局索引和分区索引都会被置于无效状态。

④ 手动置其无效:ALTER INDEX IND_OBJECT_ID UNUSABLE;。

对于分区表而言,除了ADD操作之外,TRUNCATE、DROP、EXCHANGE和SPLIT操作均会导致全局索引失效,但是可以加上UPDATE GLOBAL INDEXES子句让全局索引不失效。重建分区索引的命令为:ALTER INDEX IDX_RANG_LHR REBUILD PARTITION P1;。

分区表的索引是否失效情况如下表所示:

begin  dbms_stats.gather_table_stats('TABLE_SCHAME','TABLE_FULL_NAME',estimate_percent => dbms_stats.AUTO_SAMPLE_SIZE,cascade => true); end;---Xa库执行分析灰度数据是否导入

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章