写程序的人,往往需要分析所写的SQL语句是否已经优化过了,服务器的响应时间有多快,这个时候就需要用到SQL的STATISTICS状态值来查看了。
通过设置STATISTICS我们可以查看执行SQL时的系统情况。选项有PROFILE,IO ,TIME。介绍如下:
SET STATISTICS PROFILE ON SET STATISTICS IO ON SET STATISTICS TIME ON GO /*--你的SQL脚本开始*/ select * from TB_KYsubProject a WHERE ISNULL(a.DataType,0) IN (0,1) AND ISNULL(a.IsDelete,0)=0 and a.id not in (select b.SubID from TB_SGSubTask b where b.SubID = a.id and b.Sub_Task_Name=a.Sub_Project_Name and b.StartD=a.Sub_Project_Name and b.EndD=a.Sub_Project_Name and ISNULL(convert(varchar(36),b.GrogrammeID) ,'')='') /*--你的SQL脚本结束*/ GO SET STATISTICS PROFILE OFF SET STATISTICS IO OFF SET STATISTICS TIME OFF
效果如图所示:
计算执行时间来查看执行语句花费了的时间,以判断该条SQL语句的效率如何:
declare @d datetime
set @d=getdate()
/*你的SQL脚本开始*/
SELECT [TestCase] FROM [TestCaseSelect]
/*你的SQL脚本结束*/
select [语句执行花费时间(毫秒)]=datediff(ms,@d,getdate())