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

MSSQL
将代码页从SQL Server 7.0改变到SQL Server 2000
浅析SQL SERVER一个没有公开的存储过程
使用存储过程时一个错误的解决方法
执行一个安全的SQL Server安装
SQL导出到MYSQL的简单方法
SQL Server 7六种数据移动方法
数据库升迁从sqlserver6.5到sqlserver2000
用SQL 2000创建用户化XML流
解决SQL Server 2000之日志传送功能
保持多台服务器数据的一致性
将ACCESS转化成SQL2000需要注意的几个问题
一次特殊的SQL Server安装奇遇
实现上千万条数据的分页显示
使用用于SQL Server的IIS虚拟目录管理实用工具
SQL Server连接ACCESS数据库的实现
使用SQL Server数据转换服务升迁Access数据库
SQLServer和Access、Excel数据传输简单总结
XML文件导入SQL Server 2000
在视图中使用ORDER BY子句
内嵌或嵌入SQL和存储过程之对比

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 69 ::
收藏到网摘: 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