当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 查看SQL执行计划常用方法

MSSQL
精通数据库系列之入门:基础篇1
剖析SQL Server 2005查询通知之基础篇
用sp_lock诊断SQL Sever的性能问题
测试SQL Server业务规则链接方法
解析SQL Server数据应用在不同的数据库中
如何使用SQL Server数据库中查询累计值
逐行扫描 为你讲解几个基本SQLPLUS命令
教你一招:MSSQL数据库索引的应用
确定几个SQL Server栏中的最大值
SQL Server 2005分析服务 统一整合视图
如何使用SQL Server嵌套子查询
用TableDiff产生SQL Server同步脚本
小型商业应用选SQL Server还是Access
用SQL Server Having计算列和平均值
SQL Server 2005基于消息的应用程序介绍
在SQL Server实例之间传输登录和密码
SQL Server 2005深层工具和运行时间集
SQL Server数据库增强版备份体验
使用SQL Server 2000日志转移实现高可用性
浅谈Linq To Sql集成数据库语言的优劣

MSSQL 中的 查看SQL执行计划常用方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 102 ::
收藏到网摘: n/a

不论是做为开发DBA还是维护DBA,总是或多或少地遇到SQL执行效率或者说SQL调优问题,查看执行计划是必须的。一般我们可以用3种方法查看:

一、explain plan for

举例就足以说明其用法  

以下为引用的内容:

   sys@ORCL>explainplanfor
  2selectsysdatefromdual;
  Explained.
  sys@ORCL>select*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@ORCL>altersessionsetsql_trace=true;
Sessionaltered.

如果要在pl/sql中对session级别设置true,可以使用dbms_system这个包:

sys@ORCL> exec dbms_system.set_sql_trace_in_session(sid,serial#,true);

2、指定一下生成的trace文件的名字,便于查找:  

sys@ORCL>altersessionsettracefile_identifier='yourname';

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@ORCL>altersessionsetsql_trace=false;

三、set autotrace on

此种方法最常用,关于如何设置sql*plus的autotrace这里也不做详细介绍,因为google上面资料确实太多了。有心的朋友可以去找找,保证有一大堆适合你的资料。

举个例子,这种方法简单易懂: 

以下为引用的内容:

   ctoc@ORCL>setautotraceon
  ctoc@ORCL>selectsysdatefromdual;
  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