SQLSERVER中得到执行计划的方式
2013-01-13 22:41
204 查看
SQLSERVER中得到执行计划的方式
得到执行计划的方式有两种:1、一种是在指令的前面打开一些开关,让执行计划信息打在结果集里,这种方法比较适合在一个测试环境里对单个语句调优。
这些开关最常用的有
SET SHOWPLAN_ALL ON SET SHOWPLAN_ALL ON --(是不是reuse了一个执行计划,SQSERVERL有没有觉得缺少索引),只能在XML的输出里看到 SET STATISTICS PROFILE ON
还有如果使用SSMS的话,可以用快捷键:Ctrl+L 小写L 他会执行你的语句并显示执行计划,但是不会返回结果集
2、另一种方法是使用SQL Trace里的事件跟踪来跟踪语句的执行计划。
常用的事件有 :SHOWPLAN ALL、SHOWPLAN STATISTICS PROFILE、SHOWPLAN XML STATISTICS PROFILE
这种方法的好处是无须打开任何开关,可以用来直接跟踪应用程序的语句执行。
缺点是他会把所有语句都抓下来。如果SQLSERVER比较忙的话,输出会很大,有可能影响性能,所以要慎用
这两种方法收集的信息大部分是一样的。XML的方式会将结果以XML的结构返回,在SQL Trace里,这种结果可以用图形的方式显示执行计划以及其相关的信息。
对执行计划比较简单的语句,这样的输出方式可能比较友善。但是对于复杂的执行计划,如果用图形的方式显示,一个屏幕很难全放得下,
每一步的统计信息要鼠标点到才会显示出来,个人觉得不如文本输出格式易读性好。
相关文章推荐
- SQLSERVER中得到执行计划的两种方式
- SQLSERVER中得到执行计划的两种方式
- 清除SQL Server数据缓存和执行计划缓存,查看执行计划的各种方式对比
- 执行计划中常见index访问方式
- Oracle查看SQL执行计划的方式
- Sql Server之旅——第十一站 简单说说sqlserver的执行计划
- Sql Server之旅——第十一站 简单说说sqlserver的执行计划
- sqlplus得到执行计划的统计信息
- oracle执行计划中的连接方式
- 过sql_trace跟踪得到了该SQL的执行计划,如何看懂执行计划
- 执行计划中三种最常用连接方式的伪码实现
- oracle中得到一条SQL语句的执行时间的两种方式
- 调整SQLSERVER非最优执行计划
- 查看sql执行计划方式
- MySQL统计信息以及执行计划预估方式初探
- SQLServer 错误: 15404,维护计划无法执行
- ORACLE数据库SQL优化--->如何得到真实的执行计划
- SQLServer查询执行计划分析 - 案例
- 清除SQL Server数据缓存和执行计划缓存,查看执行计划的各种方式对比
- oracle中得到一条SQL语句的执行时间的两种方式