不论是做为开发DBA还是维护DBA,总是或多或少地遇到SQL执行效率或者说SQL调优问题,查看执行计划是必须的。一般我们可以用3种方法查看:
一、explain plan for
举例就足以说明其用法
sys@ORCLexplainplanfor
2selectsysdatefromdual;
Explained.
sys@ORCLselect*fromtable(dbms_xplan.display());
PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
--------------------------------------------------------------------
|Id|Operation|Name|Rows|Bytes|Cost|
--------------------------------------------------------------------
|0|SELECTSTATEMENT|||||
|1|TABLEACCESSFULL|DUAL||||
--------------------------------------------------------------------
Note:rulebasedoptimization
9rowsselected.
二、利用TKPROF工具
TKPROF是一个用于分析oracle跟踪文件并且产生一个更加清晰合理的输出结果的可执行工具。如果一个系统的执行效率比较低,一个比较好的方法是跟踪用户的会话并且使用TKPROF工具的排序功能格式化输出,从而找出有问题的SQL语句。
TKPROF命令后面的选项及输出文件各个列的含义在这里不做详细的介绍。 google一下就会有很多资料。
下面简单描述一下TKPROF工具的使用步骤:
1、在session级别设置sql_trace=true
sys@ORCLaltersessionsetsql_trace=true;
Sessionaltered.
如果要在pl/sql中对session级别设置true,可以使用dbms_system这个包:
sys@ORCL exec dbms_system.set_sql_trace_in_session(sid,serial#,true);
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)2、指定一下生成的trace文件的名字,便于查找:
sys@ORCLaltersessionsettracefile_identifier='yourname';
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)3、执行SQL语句。
4、利用TKPROF工具格式化输出的trace 文件:
[oracle@q1test01~] $tkprof/oracle/admin/orcl/udump/orcl_ora_10266_yourname.trc/oracle/yourname.txtexplain=user/pwdaggregate=yessys=nowaits=yessort=fchela
5、查看生成的文件再设置sql_trace=false:
sys@ORCLaltersessionsetsql_trace=false;
三、set autotrace on
此种方法最常用,关于如何设置sql*plus的autotrace这里也不做详细介绍,因为google上面资料确实太多了。有心的朋友可以去找找,保证有一大堆适合你的资料。
举个例子,这种方法简单易懂:
ctoc@ORCLsetautotraceon
ctoc@ORCLselectsysdatefromdual;
SYSDATE
---------
25-JUN-08
ExecutionPlan
----------------------------------------------------------
0SELECTSTATEMENTptimizer=CHOOSE
10TABLEACCESS(FULL)OF'DUAL'
Statistics
----------------------------------------------------------
0recursivecalls
0dbblockgets
3consistentgets
0physicalreads
0redosize
522bytessentviaSQL*Nettoclient
655bytesreceivedviaSQL*Netfromclient
2SQL*Netroundtripsto/fromclient
0sorts(memory)
0sorts(disk)
1rowsprocessed