我是靠谱客的博主 尊敬果汁,这篇文章主要介绍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内容请搜索靠谱客的其他文章。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部