Worst Performing Queries

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
WITH TMP AS
(
    SELECT TOP 100
        CAST(SUM(s.total_elapsed_time) / 1000000.0 AS DECIMAL(10, 2)) AS [Total Elapsed Time in S],
        SUM(s.execution_count) AS [Total Execution Count],
        CAST(SUM(s.total_worker_time) / 1000000.0 AS DECIMAL(10, 2)) AS [Total CPU Time in S],
        CAST(SUM(s.total_worker_time) / SUM(s.execution_count) / 1000.0 AS DECIMAL(10, 2)) AS [Avg CPU Time in MS],
        SUM(s.total_logical_reads) AS [Total Logical Reads],
        CAST(CAST(SUM(s.total_logical_reads) AS FLOAT) / CAST(SUM(s.execution_count) AS FLOAT) AS DECIMAL(10, 2)) AS [Avg Logical Reads],
        SUM(s.total_logical_writes) AS [Total Logical Writes],
        CAST(CAST(SUM(s.total_logical_writes) AS FLOAT) / CAST(SUM(s.execution_count) AS FLOAT) AS DECIMAL(10, 2)) AS [Avg Logical Writes],
        SUM(s.total_clr_time) AS [Total CLR Time],
        CAST(SUM(s.total_clr_time) / SUM(s.execution_count) / 1000.0 AS DECIMAL(10, 2)) AS [Avg CLR Time in MS],
        CAST(SUM(s.min_worker_time) / 1000.0 AS DECIMAL(10, 2)) AS [Min CPU Time in MS],
        CAST(SUM(s.max_worker_time) / 1000.0 AS DECIMAL(10, 2)) AS [Max CPU Time in MS],
        SUM(s.min_logical_reads) AS [Min Logical Reads],
        SUM(s.max_logical_reads) AS [Max Logical Reads],
        SUM(s.min_logical_writes) AS [Min Logical Writes],
        SUM(s.max_logical_writes) AS [Max Logical Writes],
        CAST(SUM(s.min_clr_time) / 1000.0 AS DECIMAL(10, 2)) AS [Min CLR Time in MS],
        CAST(SUM(s.max_clr_time) / 1000.0 AS DECIMAL(10, 2)) AS [Max CLR Time in MS],
        COUNT(1) AS [Number of Statements],
        MAX(s.last_execution_time) AS [Last Execution Time],
        s.plan_handle AS [Plan Handle]
    FROM
        sys.dm_exec_query_stats s
         
     --Most CPU consuming
    GROUP BY s.plan_handle ORDER BY SUM(s.total_worker_time) DESC
         
    -- Most read+write IO consuming
    --GROUP BY s.plan_handle ORDER BY SUM(s.total_logical_reads + s.total_logical_writes) DESC
         
    -- Most write IO consuming
    --GROUP BY s.plan_handle ORDER BY SUM(s.total_logical_writes) DESC
         
    -- Most CLR consuming
    --WHERE s.total_clr_time > 0 GROUP BY s.plan_handle ORDER BY SUM(s.total_clr_time) DESC
)
SELECT
    TMP.*,
    st.text AS [Query],
    qp.query_plan AS [Plan]
FROM
    TMP
OUTER APPLY
    sys.dm_exec_query_plan(TMP.[Plan Handle]) AS qp
OUTER APPLY
    sys.dm_exec_sql_text(TMP.[Plan Handle]) AS st

  

posted @   zping  阅读(308)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2009-09-24 检查SQL Server 2005的索引密度和碎片信息(转)
2008-09-24 SQL Server 2005 和JBOSS 4 系统运行缓慢--高并发系统探讨(1)
点击右上角即可分享
微信分享提示