清除Oracle中无用索引 改善DML性能
来源:互联网 发布:单片机蜂鸣器程序 编辑:程序博客网 时间:2024/06/06 04:43
DML性能低下,其中最严重的原因之一是无用索引的存在。所有SQL的插入、更新和删除操作在它们需要在每一行数据被改变时修改大量索引的时候会变得更慢。
许多Oracle管理人员只要看见在一个SQL 查询的WHERE语句出现了一列的话就会为它分配索引。虽然这个方法能够让SQL运行得更快速,但是基于功能的Oracle索引使得数据库管理人员有可能在数据表的行上过度分配索引。过度分配索引会严重影响关键Oracle数据表的性能。
在Oracle9i出现以前,没有办法确定SQL查询没有使用的索引。让我们看看Oracle9i提供了什么样的方法让你找到这些索引并删除它们。
过程是相当简单的。Oracle9i有一个工具能够让你使用ALTER INDEX命令监视索引的使用。然后你可以查找这些没有使用的索引并从数据库里删除它们。
下面是一段脚本,它能够打开一个系统中所有索引的监视功能:
set pages 999;
set heading off;
spoolrun_monitor.sql
select
''alter index ''||owner||''.''||index_name||'' monitoring usage;''
from
dba_indexes
where
owner 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使用了这个索引多少次,但是这个工具对于找出没有使用的索引还是很有用的。
- 清除Oracle中无用索引 改善DML性能
- 教你清除Oracle中无用的索引改善DML
- Oracle中找出无用的索引提高DML性能
- oracle 性能优化操作九: 屏蔽无用索引
- oracle 性能优化操作九: 屏蔽无用索引
- ORACLE DML 事务中索引维护在里面?
- oracle使用了索引但是查询性能没有改善(oracle的索引陷阱)
- oracle使用了索引但是查询性能没有改善(oracle的索引陷阱)
- 改善Oracle数据库性能
- 快速清除Andorid项目中无用资源
- 清除sevices中无用的服务项
- python清除字符串中无用字符
- Oracle中DML语句
- 无用索引
- SQL 入门(利用索引改善性能)
- Oracle监控用户索引使用情况,删除无用索引
- 如何查看和清除oracle无用的连接进程
- 如何查看和清除oracle无用的连接进程
- VC绘图中判断一个点与直线的距离关系的方法。
- c++ static
- 在AndroidManifest.xml中<uses-sdk /> 内属性意思
- 判断是否是平衡二叉树
- 报错:Conversion to Dalvik format failed: Unable to execute dex:
- 清除Oracle中无用索引 改善DML性能
- 位应用
- 进程线程 关系
- Xcode中使用SVN需要注意的问题
- java 判断字符串是否相等
- 检索 COM 类工厂中 CLSID 为 {} 的组件时失败,原因是出现以下错误: 80070005
- 软件工程 .
- int i=010 与int i=10 区别:
- 在Ubuntu上为Git安装diff工具Meld