a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 303|回复: 0

[考试辅导] Oracle认证辅导之对oracle执行计划进行监控

[复制链接]
发表于 2012-8-4 14:06:19 | 显示全部楼层 |阅读模式
 在我参与过的许多商店系统开发中,我发现在生产系统中创建一个索引并不需要经过详细的论证,甚至连应用程序代码也没有检查就创建了,大多数时候都是靠个人经验和感觉行事的,人们往往只会思考与创建索引有关的列是否会受到影响,完全靠临场反应,到最后数据库中往往有上百个索引创建了但可能从未使用过,或对 SQL执行性能有负面影响。作为一名DBA,我们有责任找到并清除这些闲置的以及对性能有负面影响的索引。但我们从哪里开始呢?其实Oracle已经为我们提供了解决之道。
& N) \0 n7 b9 |1 y3 G2 |  有两种基本的情况:+ z% Z9 W/ _+ c0 u
  1、 我们必须确定索引是否被使用,如果索引没有使用,只需要删除它就可以了。7 Y, G9 X5 q* a) e! X; `. ]( p. Z
  2、 如果索引被使用了,或认为索引将会被使用,对于这种索引,要确定索引对数据库性能的影响稍微有点难度。/ d- c! v  x6 R# C$ g$ X. C# P
  对于第一种情况(判断索引是否被使用),我们可以对数据库索引进行监视,关键是要监视足够长的时间,可以监视一小时,一天,一周或一个业务季度,这要取决于表上的索引是与什么相关的。
% }( ^! w* J! r- ~' A  那该如何监视一个索引呢?其实简单得很,只需要使用ALTER INDEX命令,加上MONITORING USAGE子句就可以了,还是来看一看实例吧:
4 Q8 R; z  e/ E) k- h  SQL> ALTER INDEX pk_emp MONITORING USAGE;& D2 \! p0 _; P' E  w
  Index altered.2 q7 Y! l' _0 V+ m0 G+ \  P6 `
  SQL> ALTER INDEX ix_emp_sal MONITORING USAGE;9 j$ t8 T8 Y9 Y
  Index altered.
/ X$ H- U4 Y, q$ V  当你在该表上进行SELECT,UPDATE,DELETE(没有INSERT)时,一旦使用了索引,就会在V$OBJECT_USAGE动态视图中将该索引标记为在使用中:+ A3 b. t5 D+ ?0 y* `8 M, I
  SQL> select * from emp where empno = 7844;; B6 l" j# M( d% T) A6 u9 n7 W
  EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO8 @4 A" f( M! p, {4 A
  ----- ------ --------- ---- --------- ----- ---- ------. J. V. a1 c- }7 @( u0 d" l8 u" M
  7844 TURNER SALESMAN 7698 08-SEP-81 1500 0 309 S1 ]& {% `/ x: ?
  SQL> SELECT v.index_name, v.table_name, v.monitoring, v.used, start_monitoring, end_monitoring FROM v$object_usage v, user_indexes u WHERE v.index_name = u.index_name;
: s- b2 {5 P0 b) Z  INDEX_NAME TABLE_NAME MON USE START_MONITORING END_MONITORING
$ R  l+ [" d. Z1 b, J4 r  ---------- ---------- --- --- ------------------- -------------------6 h6 \% ]( h4 j
  PK_EMP EMP YES YES 04/28/2009 10:16:51* z# @  Y4 S# O0 |
  IX_EMP_SAL EMP YES NO 04/28/2009 10:17:01
) Y0 I9 k; M' e, o1 \! |  就这么简单。显然,如果前面的SELECT语句只是查询EMP表,或许我们应该删除掉IX_EMP_SAL索引。! \8 P7 t9 _8 [! x
  如果索引已经被使用,或将被使用,在采取行动(如删除或创建索引)之前,我们必须放聪明点。为了帮助解决这些问题,Oracle为我们提供了一个新特性,INVISIBLE索引,允许我们将索引隐藏起来,隐藏的索引不能使用,但仍然可以通过INSERT,UPDATE和DELETE 进行维护。要使一个索引不可见,可以使用CREATE或ALTER INDEX INVISIBLE命令,这里以上面的IX_EMP_SAL索引为例进行演示:
. R8 y( E9 F+ C$ O- G# q% _  SQL> create index ix_emp_sal on emp(sal) INVISIBLE;4 \) e, n+ n4 C) N% {  I, H3 q
  SQL> alter index ix_emp_sal INVISIBLE;+ p. ?' N: `1 j9 O& S* q
  当一个索引被置为INVISIBLE时,应用程序就看不到它了,也不能在任何DML操作中使用它了。优化器也看不到隐藏索引,因此也不会被任何执行计划使用,除非明确指定了一个提示(hint),会话被设置为使用隐藏索引,或者数据库被设置为可以使用所有的隐藏索引,这正是某些DBA梦寐以求的功能,使用一个新的init.ora参数optimizer_use_invisible_indexes,你可以固定会话,或全系统范围内都可以使用隐藏索引,让你有机会测试新建索引在完全移动到生产环境之前的影响,可以通过设置这个初始化参数使用隐藏索引,或在SQL中增加提示使用隐藏索引,如:
# y, M  `, A+ E7 x  SQL> alter system set optimizer_use_invisible_indexetrue;6 \+ l* A" \  i" z7 y5 t
  SQL> alter session set optimizer_use_invisible_indexetrue;) h7 j8 Z: Z0 O+ Q
  SQL> select * /*+ index (emp ix_ep_sal) */ ename from emp where sal=1500;1 D! J2 [- Q! C. I% W7 B0 L
  要使一个索引从不可见状态变为可见状态,使用ALTER INDEX语句+ VISIBLE关键字即可:
0 J. F% b1 A" D/ n  SQL> alter index ix_emp_sal VISIBLE;1 q7 F7 N, w$ X4 {6 F
  此外,如果你想找出在你的数据库中哪些索引是隐藏的,可以查询DBA_,USER_或ALL_INDEXES视图中的VISIBILITY列。
, q5 s3 O5 k/ D/ |" o  SQL>select index_name, visibility! n) H' O' Z7 ^
  from dba_indexes- g) g0 ?$ W. v8 D' \) _/ m
  where index_name='IX_EMP_SAL';
, Y! I; n5 |! K  X( i' g; S4 H4 D. h; u  INDEX_NAME VISIBILIT3 A; e$ G3 w4 Q
  -------------- ---------
" g0 L& f% [! Z- t2 |  u  IX_EMP_SAL INVISIBLE; H3 a) \2 g2 i! Z5 ?. A
  在运用INVISIBLE索引功能时要注意由其它方法创建或修改的隐藏索引,如果你以前写有一个SQL查看索引的结构,现在需要修改一下增加检查 VISIBILITY列,否则你看到的仅仅是索引的部分信息,当执行了大量的INSERT,UPDATE或DELETE操作时,这可能会变成一个隐藏的恶梦。
2 ~0 ?3 Q4 W: S# i" e( S  索引的可用性一向有些黑色艺术,对于删除一个索引是否会对性能产生影响从来都没有明确的判断标准,现在通过监视索引的可用性,并可以修改索引的可见性,DBA完全可以更好地测试和验证索引的可用性了。 #g_kclist{font-size:12px;width:570px;float:none; margin-top:5px; clear:right}#g_kclist a{color:#000; text-decoration:none}#g_kclist h2{margin:0px;padding:0px;font-size:14px; text-align:center;background:url(http://www.thea.cn/zt/zt_img/zczhongduan.gif) no-repeat;line-height:31px;color:#fff}#g_kclist table{line-height:25px;background:#B0DA90;margin-top:8px}#g_kclist table td{ text-align:center;background:#fff}#g_kclist table td.td1 a{color:#f00}#g_kclist table th{background:#F2F7ED;color:#525F46}
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-3-29 17:46 , Processed in 0.175838 second(s), 21 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表