首页 > 开发 > 综合 > 正文

寻找没有使用的索引

2024-07-21 02:13:17
字体:
来源:转载
供稿:网友

那些存在但是没有使用的索引是以个导致dml语言执行效率低下的严重问题,所有的 sql语句如:inserts、updates、和deletes当它们要更新表中含有很多索引的行时将运行得很慢。oracle专业人士看到一列应用到sql查询语句的where语句时将会重新设置索引,这有可能使得sql语句运行更快。oracle提供的索引功能可能会重新配置索引到这些表中的列,这种重新配置的索引将削弱装载oracle自关联表的执行效率。在oracle9i前,没有办法表示哪些sql查询语句没有使用的索引。现在我们通过oracle9i提供的方法可以找到和删除这些没有使用的索引。oracle9i提供一个工具让你使用alter index 命令来监控索引使用情况。你可以定位和查找那些没有使用的索引然后从数据库中删除。

下面一段代码将打开对系统中使用的索引的监控。

set pages 999;

set heading off;

spool run_monitor.sql

select

‘alter index ‘||owner||’.’||index_name||’ monitoring usage;’

from

   dba_indexes

where

   ower not in (‘sys’,’system’,’perfstat’)

;

spool off;

@run_monitor

等到这些重要的sql在数据库中执行完毕,查寻新的v$object_usage 视图

select

index_name,

table_name,

mon,

used

from

   v$object_usage;

如下所示,我们可以看到v$object_usage中有一列声明为used。它可以设置成yes或者no,它不会告诉你oracle使用这个索引要多少时间,但是这个工具有利于来研究不使用的索引。

index_name                        table_name   mon     used

---------------                           -------------------   ---------    ---------

customer_last_name_idx         customer     yes      no

 

国内最大的酷站演示中心!
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表