监控和跟踪索引使用情况

文章作者 100test 发表时间 2007:03:14 13:53:52
来源 100Test.Com百考试题网


在 Oracle9i 之前,监控索引使用的唯一方法是执行他们的程序库缓中的所有SQL,然后手工记下所有被使用的索引。
  
  最近的研究发现 Oracle 数据库所使用的索引从来没有达到过可用索引数的1/4,或者其用法与其开始设计的意图不相同。未用的索引浪费空间,而且还会降低 DML 的速度,尤其是 UPDATE 和 INSERT 语句。
  
  Oracle9i提供一个简单的方法来打开和关闭索引使用跟踪,那就是MONITORING USAGE 子句:
  
  alter index cust_name_idx monitoring usage.
  alter index cust_name_idxnomonitoring usage.
  
  这个命令使用V$OBJECT_USAGE 视图和 USAGE 字段来判断索引是否被访问过。你可能期望 USAGE 字段是一个数字值,这样你就可以知道索引被使用的次数,但不幸的是,它的取值只为YES 或NO。
  
  但不管怎样,如果你接手一个以前开发的数据库,而且老数据库在没有考虑到 SQL 访问表的情况下创建了索引,那么这个工具对你是很有用的。INDEX MONITORING 特性的开销非常小,而对定位和丢弃不需要的索引很有帮助。
  
  下面是一个打开整个方案的索引监控的简单 SQL*Plus 脚本:
  
  set pages 999
  set heading off
  
  spool run_mon.sql
  
  0select
    alter index ||
    index_name||
    monitoring usage.
  from
    dba_indexes
  where
    owner = SCOTT.
  
  spool off
  
  @run_mon

相关文章


使用新的list分割方法提高灵活性
Oracle9i新特性研究系列之七
[Oracle]DBMS_REPAIR包修复损坏数据块(1)
[Oracle]DBMS_REPAIR包修复损坏数据块(2)
监控和跟踪索引使用情况
在9i里对基于函数的索引进行仅索引扫描
Oracle10g中新的SQLoptimizerhints
Oracle回滚段表空间文件丢损的处理
忘却Oracle的5个方面
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛