监控Oracle索引的使用情况
2011-01-25 11:53
309 查看
从Oracle 9i开始,可以监控Oracle索引的使用情况,具体方法如下:
alter index <schema>.<index> MONITORING USAGE;
对某个INDEX开启监控后,就可以观察该INDEX是否被使用:
如果要取消对索引使用情况的监控,使用下列SQL:
alter index <schema>.<index> NOMONITORING USAGE;
要注意的是:索引使用情况监控,会增加部分系统开销。
select index_name,monitoring,used,start_monitoring,end_monitoring
from v$object_usage;
INDEX_NAME MONITORING USED START_MONITORING END_MONITORING
----------------------------------------------------------------------------------------
AA NO YES 06/04/2006 12:02:38 06/05/2006 13:47:39
AA1 NO YES 06/04/2006 12:02:40 06/05/2006 13:47:39
要注意的是,由于V$OBJECT_USAGE视图限制了只显示当前用户下被监控的索引的情况,因此,通过其他用户登录数据库,将无法看到,如果要查看所有用户下的被监控的索引的情况,使用如下SQL:
select u.name owner, io.name index_name, t.name table_name,
decode(bitand(i.flags, 65536), 0, 'NO', 'YES') monitoring,
decode(bitand(ou.flags, 1), 0, 'NO', 'YES') used,
ou.start_monitoring start_monitoring,
ou.end_monitoring end_monitoring
from sys.user$ u, sys.obj$ io, sys.obj$ t, sys.ind$ i, sys.object_usage ou
where i.obj# = ou.obj#
and io.obj# = ou.obj#
and t.obj# = i.bo#
and u.user# = io.owner#
alter index <schema>.<index> MONITORING USAGE;
对某个INDEX开启监控后,就可以观察该INDEX是否被使用:
如果要取消对索引使用情况的监控,使用下列SQL:
alter index <schema>.<index> NOMONITORING USAGE;
要注意的是:索引使用情况监控,会增加部分系统开销。
select index_name,monitoring,used,start_monitoring,end_monitoring
from v$object_usage;
INDEX_NAME MONITORING USED START_MONITORING END_MONITORING
----------------------------------------------------------------------------------------
AA NO YES 06/04/2006 12:02:38 06/05/2006 13:47:39
AA1 NO YES 06/04/2006 12:02:40 06/05/2006 13:47:39
要注意的是,由于V$OBJECT_USAGE视图限制了只显示当前用户下被监控的索引的情况,因此,通过其他用户登录数据库,将无法看到,如果要查看所有用户下的被监控的索引的情况,使用如下SQL:
select u.name owner, io.name index_name, t.name table_name,
decode(bitand(i.flags, 65536), 0, 'NO', 'YES') monitoring,
decode(bitand(ou.flags, 1), 0, 'NO', 'YES') used,
ou.start_monitoring start_monitoring,
ou.end_monitoring end_monitoring
from sys.user$ u, sys.obj$ io, sys.obj$ t, sys.ind$ i, sys.object_usage ou
where i.obj# = ou.obj#
and io.obj# = ou.obj#
and t.obj# = i.bo#
and u.user# = io.owner#
相关文章推荐
- 监控Oracle索引的使用情况
- Oracle监控用户索引使用情况,删除无用索引
- 浅谈在Tomcat中监控JVM内存使用情况
- Ubuntu16.04下实时监控CPU/GPU内存的使用情况
- 使用Java自带的VisualVM监控远程主机JVM内存使用情况
- 用 jconsole 监控 WebSphere AppServer JVM使用情况
- linux管理(二)---网络使用情况的监控
- 使用zabbix监控大机Lpar CPU使用情况
- solaris上应该如何监控CPU使用情况
- 编写shell脚本监控系统负载、CPU和内存使用情况
- zabbix监控windows服务器上进程的内存使用情况
- Linux SUSE下使用监控空间使用情况,并发送邮件告知
- Solaris内存监控 & solaris查看内存使用情况
- 使用JProfiler监控JBoss运行情况
- 监控Java应用程序Windows内存使用情况
- 监控JVM内存使用情况,剩余空间小于2M时报警
- Solaris内存监控 & solaris查看内存使用情况 LINUX下查看CPU使用率的命令
- 实战Nagios NSCA方式监控Linux系统资源使用情况 -- Nagios配置篇 -- 被监控端
- 使用SQLServer Audit来监控触发器的启用、禁用情况
- 浅谈在Tomcat中监控JVM内存使用情况