寻找没有使用的索引

ZDNet软件频道 时间:2003-05-19 作者:翻译:Java研究组织-周旺重 |  我要评论()
本文关键词:oracletips
在ORACLE9i前,没有办法表示那些没有使用的索引。现在我们通过ORACLE9i提供的方法可以找到和删除没有使用的索引。
本文译自Builder.com,未经许可请勿转载那些存在但是没有使用的索引是以个导致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



责任编辑:炒饭

欢迎评论或投稿


百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134