WEB开发网
开发学院数据库Oracle Oracle9i中监视索引的使用 阅读

Oracle9i中监视索引的使用

 2006-08-05 11:58:32 来源:WEB开发网   
核心提示:介绍DBA和开发者都喜欢索引,它们可以加速查询搜索,Oracle9i中监视索引的使用,特别是在一个数据仓库的环境中,因为这时数据库会接收到许多ad-hoc请求,要开始监控一个索引的使用,使用这个命令:ALTER INDEX index_name MONITORING USAGE;要停止监控一个索引,要避免全表搜索,我们

介绍

DBA和开发者都喜欢索引。它们可以加速查询搜索,特别是在一个数据仓库的环境中,因为这时数据库会接收到许多ad-hoc请求。要避免全表搜索,我们一般在每个可能被搜索的列中建立索引。不过索引会占用许多的表空间;在许多的情况下,索引比被索引的表消耗更多的存储空间。在插入和删除行的时候,索引还会引入额外的开销。在Oracle9i之前,要知道一个索引是否被使用是困难的,因此许多数据库都有许多没用的索引。这篇文章的目的就是向你介绍通过Oracle9i中的新特性来辨别未使用的索引。

辨别未使用的索引

Oracle9i提供了一个新的技术来监控索引以辨别索引有否被使用。要开始监控一个索引的使用,使用这个命令:

ALTER INDEX index_name MONITORING USAGE;

要停止监控一个索引,输入:

ALTER INDEX index_name NOMONITORING USAGE;

在v$objec_usage视图中包含有索引监控的使用信息。

CREATE OR REPLACE VIEW SYS.V$OBJECT_USAGE
(
INDEX_NAME,
TABLE_NAME,
MONITORING,
USED,
START_MONITORING,
END_MONITORING
)
AS
select io.name, t.name,
decode(bitand(i.flags, 65536), 0, 'NO', 'YES'),
decode(bitand(ou.flags, 1), 0, 'NO', 'YES'),
ou.start_monitoring,
ou.end_monitoring
from sys.obj$ io, sys.obj$ t, sys.ind$ i, sys.object_usage ou
where io.owner# = userenv('SCHEMAID')
and i.obj# = ou.obj#
and io.obj# = ou.obj#
and t.obj# = i.bo#
/
COMMENT ON TABLE SYS.V$OBJECT_USAGE IS
'Record of index usage'
/
GRANT SELECT ON SYS.V$OBJECT_USAGE TO "PUBLIC"
/

1 2 3 4  下一页

Tags:Oraclei 监视 索引

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接