SQL Server中SQL语句的执行效率查看方法

之前在练习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

查询结果:

 

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

posted @   #谭  阅读(1515)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示