给自己一点时间接受自己,爱自己,趁着下午茶的时间来学习推荐的查看SQL执行计划常用方法,过去的都会过去,迎接崭新的开始,释放更美好的自己。
不论是做为开发DBA还是维护DBA,总是或多或少地遇到SQL执行效率或者说SQL调优问题,查看执行计划是必须的。一般我们可以用3种方法查看:
一、explain plan for
举例就足以说明其用法
[email protected]
2selectsysdatefromdual;
Explained.
[email protected]*fromtable(());
PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
--------------------------------------------------------------------
|Id|Operation|Name|Rows|Bytes|Cost|
--------------------------------------------------------------------
|0|SELECTSTATEMENT|||||
|1|TABLEACCESSFULL|DUAL||||
--------------------------------------------------------------------
9rowsselected.
二、利用TKPROF工具
TKPROF是一个用于分析oracle跟踪文件并且产生一个更加清晰合理的输出结果的可执行工具。如果一个系统的执行效率比较低,一个比较好的方法是跟踪用户的会话并且使用TKPROF工具的排序功能格式化输出,从而找出有问题的SQL语句。
TKPROF命令后面的选项及输出文件各个列的含义在这里不做详细的介绍。 google一下就会有很多资料。
下面简单描述一下TKPROF工具的使用步骤:
1、在session级别设置sql_trace=true
[email protected]_trace=true;
Sessionaltered.
如果要在pl/sql中对session级别设置true,可以使用dbms_system这个包:
[email protected]exec (,#,);
2、指定一下生成的trace文件的名字,便于查找:
[email protected]_identifier='yourname';
3、执行SQL语句。
4、利用TKPROF工具格式化输出的trace 文件:
[[email protected]~] $tkprof/oracle/admin/orcl/udump/
5、查看生成的文件再设置sql_trace=false:
[email protected]_trace=false;
三、set autotrace on
此种方法最常用,关于如何设置sql*plus的autotrace这里也不做详细介绍,因为google上面资料确实太多了。有心的朋友可以去找找,保证有一大堆适合你的资料。
举个例子,这种方法简单易懂:
[email protected]
[email protected];
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