我是靠谱客的博主 尊敬果汁,最近开发中收集的这篇文章主要介绍SQL Server: 对T-SQL语句进行性能分析清除SQL Server的数据和过程缓冲区用SET STATISTICS IO和SET STATISTICS TIME进行性能分析,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

清除SQL Server的数据和过程缓冲区


在对SQL语句进行性能分析前,首先要执行以下命令(但禁止在在线服务器上执行此命令!)以清除SQL Server的数据和过程缓冲区:

DBCC DROPCLEANBUFFERS;
DBCC FREEPROCCACHE;

GO

Notes:

  1. 这两条命令的作用是清除SQL Server的数据和过程缓冲区,使得我们进行性能分析时,每次执行的查询都在同一起点上。如果不这么做,对查询所得到的执行时间和I/O消耗就不具有可比性了。
  2. 执行这两条命令需要sysadmin权限。You have to be an member of the sysadmin role to issue these 2 commands.
  3. 禁止在生产环境的服务器上执行此命令!原因,正如 Notes[1] 对它的作用的解释。

用SET STATISTICS IO和SET STATISTICS TIME进行性能分析


在SQL Server Management Studio里执行:
SET STATISTICS PROFILE OFF;
SET STATISTICS IO ON;
SET STATISTICS TIME ON;

GO

-- // The SQL statement to analysis

GO

会得到以下这样的统计结果:

(8653 row(s) affected)
Table '...'. Scan count 1, logical reads 160, physical reads 4, read-ahead reads 158, lob logical reads 0, lob physical reads 0, lob read-ahead reads 0.

 SQL Server Execution Times:
   CPU time = 16 ms,  elapsed time = 91 ms.


最后

以上就是尊敬果汁为你收集整理的SQL Server: 对T-SQL语句进行性能分析清除SQL Server的数据和过程缓冲区用SET STATISTICS IO和SET STATISTICS TIME进行性能分析的全部内容,希望文章能够帮你解决SQL Server: 对T-SQL语句进行性能分析清除SQL Server的数据和过程缓冲区用SET STATISTICS IO和SET STATISTICS TIME进行性能分析所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(62)

评论列表共有 0 条评论

立即
投稿
返回
顶部