Oracle提供一个监控索引的方法,来确定索引是否被使用。如果索引没有被使用,就可以删除它们以减少不必要的语句的开销。因为表上的大量不必要的索引可能会降低DML语句的性能,给数据库性能产生压力。所以生产环境上,以根据业务增长情况定期监控、分析数据库索引的使用,特别是一些大表上的索引,提升数据库事务提交的性能。

--查看表上的索引

SQL> Selectindex_name,table_name,num_rows From dba_indexes i Where i.table_name ='WEBSITE_VIEW_TB' ;

INDEX_NAME                     TABLE_NAME                       NUM_ROWS

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

CURRTIME_IDX                   WEBSITE_VIEW_TB                  79284331

ORDERNO_IDX                    WEBSITE_VIEW_TB                   2021984

ORDERSOURCE_IDX                WEBSITE_VIEW_TB                    938174

--开启索引监控

SQL> ALTER INDEX CURRTIME_IDX MONITORING USAGE;

Index altered

--查看索引监控

SQL> Select * From v$object_usage;

INDEX_NAME                     TABLE_NAME                     MONITORING USED START_MONITORING    END_MONITORING

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

CURRTIME_IDX                   WEBSITE_VIEW_TB                YES          NO     08/20/2013 14:19:48

注意:

如果开启了索引监控功能,用v$object_usage视图可以查看正在被监控的索引记录,USED列表示在开启索引监控过程中索引是否被使用,MONITORING列表示是否开启了索引监控,START_MONITORING表示开启索引监控的开始时间,END_MONITORING表示开启索引监控的结束时间

--执行查询语句,使用被监控的索引

SQL> Select Count(*) From log.WEBSITE_VIEW_TB t

2 Where t.currtime between to_date('2013-1-27','yyyy-mm-dd')And to_date('2013-1-28','yyyy-mm-dd');

COUNT(*)

----------

750603

--可以看到记录的USED列值变成了YES,表示索引被使用过。

SQL> Select * From v$object_usage;

INDEX_NAME                     TABLE_NAME                     MONITORING USED  START_MONITORING    END_MONITORING

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

CURRTIME_IDX                   WEBSITE_VIEW_TB                YES         YES       08/20/2013 14:19:48

--分析完毕后,关闭索引监控,因为监控也会占用一定的资源

SQL> ALTER INDEX CURRTIME_IDX NOMONITORING USAGE;

Index altered

--可以看到MONITORING列变为NO,END_MONITORING列被填充,索引停止监控

SQL> Select * From v$object_usage;

INDEX_NAME                     TABLE_NAME                    MONITORING USED  START_MONITORING   END_MONITORING

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

CURRTIME_IDX                   WEBSITE_VIEW_TB               NO           YES      08/20/2013 14:19:48      08/20/2013 14:32:18

--再次执行查询,监控记录无变化

SQL> Select Count(*) From log.WEBSITE_VIEW_TB t

2 Where t.currtime between to_date('2013-1-27','yyyy-mm-dd') And to_date('2013-1-28','yyyy-mm-dd');

COUNT(*)

----------

750603

SQL> Select * From v$object_usage;

INDEX_NAME                     TABLE_NAME                     MONITORING USED  START_MONITORING    END_MONITORING

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

CURRTIME_IDX                   WEBSITE_VIEW_TB                NO           YES      08/20/2013 14:19:48      08/20/2013 14:32:18

--再次开启索引监控,相应监控记录值又发生了变化

SQL> ALTER INDEX CURRTIME_IDX MONITORING USAGE;

Index altered

SQL> Select * From v$object_usage;

INDEX_NAME                     TABLE_NAME                     MONITORING USED START_MONITORING    END_MONITORING

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

CURRTIME_IDX                   WEBSITE_VIEW_TB                YES        NO  08/20/2013 14:34:15

总结:

虽然v$object_usage表能记录索引监控和使用的状态,但它不能统计索引被使用的次数和频率,只记录了在开启索引监控的时间段索引是否被使用过,这一点要值的注意。

Oracle 监控索引使用的更多相关文章

  1. Oracle 重建索引脚本

    该指数是一个有力的武器,以提高数据库的查询性能. 没有索引,喜欢同样的标签库没有书籍,找书,他们想预订比登天还难.中,尤其是在批量的DML的情形下会产生对应的碎片.以及B树高度会发生对应变化.因此能够 ...

  2. [转]Oracle 重建索引的必要性

    http://blog.csdn.net/leshami/article/details/23763963 索引重建是一个争论不休被不断热烈讨论的议题.当然Oracle官方也有自己的观点,我们很多DB ...

  3. Oracle监控用户索引使用情况,删除无用索引

    监控当前业务用户索引 一段时间后查询从未被使用的索引,删除无用索引 停止监控索引 1. 监控当前用户所有索引 得到监控所有索引的语句: select 'alter index ' || index_n ...

  4. oracle 监视索引是否使用

    公司的大数据产品已经升级了四个版本了,最新版本的数据计算,大部分从oracle迁移到hadoop中了. 但是也有客户使用旧版的系统,不过,不去管它.只说我管理的. 在我接过这个数据库管理的时候,发现有 ...

  5. Oracle中索引的使用 索引性能优化调整

    索引是由Oracle维护的可选结构,为数据提供快速的访问.准确地判断在什么地方需要使用索引是困难的,使用索引有利于调节检索速度. 当建立一个索引时,必须指定用于跟踪的表名以及一个或多个表列.一旦建立了 ...

  6. Oracle索引梳理系列(七)- Oracle唯一索引、普通索引及约束的关系

    版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

  7. oracle唯一索引与普通索引的区别和联系以及using index用法

    oracle唯一索引与普通索引的区别和联系 区别:唯一索引unique index和一般索引normal index最大的差异是在索引列上增加一层唯一约束.添加唯一索引的数据列可以为空,但是只要尊在数 ...

  8. oracle建索引的可选项

    oracle中建索引可能大家都会,但是建索引是有几个选项参数却很少有人关注,在某些特殊环境下,可能会非常有用,下面一一说明: 1.NOSORT,记录排序可选项. 默认情况下,在表中创建索引的时候,会对 ...

  9. oracle 创建索引思考(转)

    在Oracle数据库中,创建索引虽然比较简单.但是要合理的创建索引则比较困难了. 笔者认为,在创建索引时要做到三个适当,即在适当的表上.适当的列上创建适当数量的索引.虽然这可以通过一句话来概括优化的索 ...

随机推荐

  1. Github上图文演示仓库创建

    1.注册账号 https://github.com/ 2.注册完账号 创建仓库 a.点击按钮 Start a project b.填写信息,点击按钮 Create repository c.仓库信息( ...

  2. 环状DNA序列

    大意: 一个DNA序列是环状的,这意味着有N个碱基的序列有N种表示方法(假设无重复).而这N个序列有一种最小的表示,这个最小表示的意思是这个序列的字典序最小(字典序的意思是在字典中的大小 比如ABC& ...

  3. 基础-函数3(IIFE立即执行函数)

    参考链接: http://benalman.com/news/2010/11/immediately-invoked-function-expression/#iife http://segmentf ...

  4. javascript判断设备类型-手机(mobile)、安卓(android)、电脑(pc)、其他(ipad/iPod/Windows)等

    使用device.js检测设备并实现不同设备展示不同网页 html代码: <!doctype html> <html> <head> <meta charse ...

  5. C#小数点位数处理方法

    //方法一: //保留小数位数,并能四舍五入 DecimalFormat de = new DecimalFormat("0.00"); System.out.println(de ...

  6. 《C和指针》章节后编程练习解答参考——第8章

    8.1 #include <stdio.h> int main (void) { int a, b, c, d; // 不使用嵌套花括号初始化 unsigned ][][][] = { , ...

  7. linux源码Makefile的详细分析

    目录 一.概述 1.本文的意义 2.Linux内核Makefile文件组成 二.Linux内核Makefile的“make解析”过程 1 顶层Makefile阶段 1.从总目标uImage说起 2.v ...

  8. ASP.NET MVC轻教程 Step By Step 10——模型验证

    在使用表单获取用户输入的数据时,我们必须对数据进行有效性验证,因为来自网络的信息都是不可信的.同时也要给用户即时的反馈,避免让用户感到困惑.这就涉及到数据验证的范畴. 数据验证最直接的做法是在服务器端 ...

  9. 【原】K3Cloud平台开发之Python插件

    有时候我们的表单可能很简单,只是一个简单交互的表单,但有可能还是要劳师动众的给它建个工程写个插件,是不是很不爽?例如我有如下一个表单: 功能很简单就是选个业务对象,收集绑定几个字段名,然后确定返回一个 ...

  10. SpringMVC源码阅读(三)

    先理一下Bean的初始化路线 org.springframework.beans.factory.support.AbstractBeanDefinitionReader public int loa ...