我是靠谱客的博主 尊敬果汁,最近开发中收集的这篇文章主要介绍SQL Server: 对T-SQL语句进行性能分析清除SQL Server的数据和过程缓冲区用SET STATISTICS IO和SET STATISTICS TIME进行性能分析,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
清除SQL Server的数据和过程缓冲区
在对SQL语句进行性能分析前,首先要执行以下命令(但禁止在在线服务器上执行此命令!)以清除SQL Server的数据和过程缓冲区:
DBCC DROPCLEANBUFFERS;
DBCC FREEPROCCACHE;
GO
Notes:
- 这两条命令的作用是清除SQL Server的数据和过程缓冲区,使得我们进行性能分析时,每次执行的查询都在同一起点上。如果不这么做,对查询所得到的执行时间和I/O消耗就不具有可比性了。
- 执行这两条命令需要sysadmin权限。You have to be an member of the sysadmin role to issue these 2 commands.
- 禁止在生产环境的服务器上执行此命令!原因,正如 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进行性能分析所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复