- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
利用Oracle 0g SQL优化器(STA)优化语句
SQL优化器 SQL Tuning Advisor STA 是Oracle10g中推出的帮助DBA优化工具,它的特点是简单、智能,DBA值需要调用函数就可以给出一个性能很差的语句的优化结果。下面介绍一下它的使用。
使用STA一定要保证优化器是CBO模式下。
一、利用STA优化语句
对于问题语句的收集,可以通过Oracle10g的另一个自动化工具:数据库自动诊断监视工具(ADDM)。它的使用可以参照我的另一篇文章《Oracle10g数据库自动诊断监视工具 ADDM 使用指南》。
我们下面简单介绍一下如何优化一条找到的问题语句。正如前面所述说的,STA是用起来很简单(只要你会调用存储过程,都能使用这个工具),三个步骤就可以完成一次语句调优。
测试环境创建:
SQL CREATE TABLE bigtab AS SELECT rownum as id, a.* FROM dba_objects a;
Table created.
SQL create table smalltab as select rownum as id, a.* FROM dba_tables a;
Table created.
SQL ALTER TABLE bigtab MODIFY empno NUMBER ;
Table altered.
SQL DECLARE
2 n NUMBER;
3??? BEGIN
4 FOR n IN 1..100
5 LOOP
6 INSERT INTO bigtab SELECT rownum as id, a.* FROM dba_objects a;
7 COMMIT;
8 END LOOP;
9?? END;
/
PL/SQL procedure successfully completed.
这里创建一张大表和一张小表,并且都没有索引,下面执行一个查询:
SQL set timing on
SQL set autot on
SQL select count * from bigtab a, smalltab b where a.object_name b.table_name;
? COUNT * 135000
Elapsed: 00:00:05.59
Execution Plan
Plan hash value: 座机电话号码80
| Id? | Operation | Name | Rows? | Bytes | Cost %CPU | Time |
|?? 0 | SELECT STATEMENT??? | | 1 |??? 36 |? 3550?? 2 | 00:00:43 |
|?? 1 |? SORT AGGREGATE | | 1 |??? 36 | | |
|*? 2 |?? HASH JOIN | |?? 155K| ?5462K|? 3550?? 2 | 00:00:43 |
|?? 3 |??? TABLE ACCESS FULL| SMALLTAB |? 1223 | 22014 |??? 11?? 0 | 00:00:01 |
|?? 4 |??? TABLE ACCESS FULL| BIGTAB?? |? 1205K|??? 20M|? 3526?? 1 | 00:00:43 |
Predicate Information identified by operation id : 2 - access A.OBJECT_NAME B.TABLE_NAME
Statistics 0? recursive calls 0? db block gets 16013? consistent gets 14491? physical reads 0? redo size 412? bytes sent via SQL*Net to client 385? bytes received via SQL*Net from client 2? SQL*Net roundtrips to/from client 0? sorts memory 0? sorts disk 1? rows processed
可以看出这个语句执行性能很差:16013 consistent gets。
第一步:创建优化任务并执行
通过调用函数CREATE_TUNING_TASK来创建优化任务,调用存储过程EXECUTE_TUNING_TASK执行该任务:
SQL set autot off
SQL set timing off
SQL DECLARE
? 2??? my_task_name VARCHAR2 30 ;
? 3??? my_sqltext?? CLOB;
? 4? B
文档评论(0)