oracle怎么判断索引是否失效

在oracle中,可以利用“select status from user_indexes where index_name=索引名称;”语句判断索引是否失效;若返回的结果是VALID,则表示索引没有失效,否则表示索引失效。 本教程操作环境:W

    <blockquote><p>在oracle中,可以利用“select status from user_indexes where index_name='索引名称';”语句判断索引是否失效;若返回的结果是VALID,则表示索引没有失效,否则表示索引失效。</p></blockquote>

本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。

oracle怎么判断索引是否失效

语法如下:

示例如图所示:

20.png

扩展知识:

索引失效解决方法

1. 选用适合的Oracle优化器

Oracle的优化器共有3种:

a. RULE (基于规则) b. COST (基于成本) c. CHOOSE (选择性)。

设置缺省的优化器,可以通过对init.ora文件中OPTIMIZER_MODE参数的各种声明,如RULE,COST,CHOOSE,ALL_ROWS,FIRST_ROWS 。你当然也在SQL句级或是会话(session)级对其进行覆盖。

为了使用基于成本的优化器(CBO, Cost-Based Optimizer) , 你必须经常运行analyze 命令,以增加数据库中的对象统计信息(object statistics)的准确性。

如果数据库的优化器模式设置为选择性(CHOOSE),那么实际的优化器模式将和是否运行过analyze命令有关。如果table已经被analyze过, 优化器模式将自动成为CBO , 反之,数据库将采用RULE形式的优化器。

(分析table

在缺省情况下,Oracle采用CHOOSE优化器, 为了避免那些不必要的全表扫描(full table scan), 你必须尽量避免使用CHOOSE优化器,而直接采用基于规则或者基于成本的优化器。

2、‍重建索引

给该语句加上hint后,强制其使用'RECORD_ENTITYID' 这个索引

sql语句变成这样

引用

后来经过测试,在不加hint的情况下,对该表和两个索引执行analyze 后,同样也能使用 'RECORD_ENTITYID' 这个索引。但是因为该表更新颇为频繁,不知道要多久就要再分析一次

推荐教程:《Oracle视频教程》

以上就是oracle怎么判断索引是否失效的详细内容,更多请关注每日运维其它相关文章!