【MS SQL】通过执行计划来分析SQL性能

原文: 【MS SQL】通过执行计划来分析SQL性能

如何知道一句SQL语句的执行效率呢,只知道下面3种:

1、通过SQL语句执行时磁盘的活动量(IO)信息来分析:SET STATISTICS IO ON (开启) / SET STATISTICS IO OFF (关闭)

2、通过SQL语句执行时语法分析、编译以及执行所消耗的时间:SET STATISTICS TIME ON (开启) / SET STATISTICS TIME OFF (关闭)

3、通过执行计划查看:Ctrl + L

 ----------------------------------------------------------------------------------------------------------------------------------------------------

首先有个表,表的数据不多,所以执行结果比较起来可能不会太明显...

 

1、先执行 SET STATISTICS IO ON & SET STATISTICS TIME ON;

 

2、执行查询语句,选择"消息"选项页;为方便查看,使用了聚合函数、GROUP BY、ORDER BY

【我们并未查询表:Worktable,为何会有Worktable的记录呢,最最最后面有注明。】

3、按Ctrl + L 组合键,查看执行计划:

==================================================================================

如何查看表的设计或SQL语句是否是优化的,这边以建立索引后执行相同的SQL语句,来比对执行结果。

==================================================================================

1、建立索引。(为测试性能而建立,未必适用于真实场景)

2、建立索引后执行语句所消耗的时间:

【这边没有出现Worktable的记录,最最最后面有注明。】

3、按Ctrl + L 组合键,查看执行计划:

 

====是不是感觉不到什么变化?下图是未建立索引和建立索引相同SQL语句执行效能的对比=====

 

由于测试数据较少,结果并不明显。

但可以通过掌握 "IO读取"、"时间开销"、"执行计划"的参数变化,对SQL性能进行调优。 

 

==============================================================

【Worktable】在MSDN说明:  

关系引擎可能需要生成一个工作表以执行 SQL 语句中指定的逻辑操作。工作表是用于保存中间结果的内部表。

 某些 GROUP BYORDER BY  UNION查询中会生成工作表。

 例如,如果 ORDER BY 子句引用了不为任何索引涵盖的列,则关系引擎可能需要生成一个工作表以按所请求的顺序对结果集进行排序。

 工作表有时也用作临时保存执行部分查询计划所得结果的假脱机。工作表在tempdb中生成,并在不再需要时自动删除。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值