之前在练习SQL查询的时候,对于同一个需求可以通过不同的sql语句得到想要的数据。所以想知道不同的sql语句的查询效率,就有了下面的内容。

例如:-- 16、查询出只选修了2门课程的全部学生的学号和姓名

select sid,sname from student where sid in
(select sid from sc group by sid having count(*) =2)

select 学号=sid,姓名=sname from student st where 
(select count(*) from (select distinct cid from sc where sid=st.sid) as temp) =2

在SQL Server中可以通过SQL语句来查询执行过的语句的执行效率,代码如下:

select top 1000 
st.text as '执行的sql语句',
qs.execution_count as '执行的次数',
qs.total_elapsed_time as '耗时',
qs.total_logical_reads as '逻辑读取次数',
qs.total_logical_writes as '逻辑写入次数',
qs.total_physical_reads as '物理读取次数',
qs.creation_time as '执行时间',
qs.creation_time as '语句编译时间'
from sys.dm_exec_query_stats qs CROSS APPLY
sys.dm_exec_sql_text(qs.sql_handle) st
order by qs.creation_time desc

查询结果:

nosql 性能测试 测试sql server效率_sql语句

 

附:如果执行的sql语句过多,不方便找到要检查的SQL语句。可以在SQL Server中清理一下缓存。
       清理缓存的语句:dbcc freeProcCache