zoukankan      html  css  js  c++  java
  • 通过sql的DMV查看数据库使用状态

    --数据库隔离级别 读未提交
    SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
    
    --查找每次执行时引发I/O最多的前10位的查询
    SELECT TOP 10
            total_logical_reads / execution_count avg_logical_reads ,
            total_logical_writes / execution_count avg_logical_writes ,
            total_physical_reads / execution_count avg_physical_reads ,
            execution_count ,
            ( SELECT    SUBSTRING(text, statement_start_offset / 2 + 1,
                                  CASE WHEN statement_end_offset = -1
                                       THEN LEN(CONVERT(NVARCHAR(MAX), text)) * 2
                                       ELSE statement_end_offset
                                  END - statement_start_offset / 2)
              FROM      sys.dm_exec_sql_text(sql_handle)
            ) query_text ,
            plan_handle
    FROM    sys.dm_exec_query_stats
    ORDER BY total_logical_reads + total_logical_writes DESC;
    
    --查找查询消耗时间最长的前20个查询语句
    SELECT TOP 20
            CAST(qs.total_elapsed_time / 1000000.0 AS DECIMAL(28, 2)) [Total Elapsed Duration(s)] ,
            qs.execution_count ,
            ( SUBSTRING(text, statement_start_offset / 2 + 1,
                        CASE WHEN statement_end_offset = -1
                             THEN LEN(CONVERT(NVARCHAR(MAX), text)) * 2
                             ELSE statement_end_offset
                        END - statement_start_offset / 2) ) query_text ,
            qp.query_plan
    FROM    sys.dm_exec_query_stats qs
            CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) qt
            CROSS APPLY sys.dm_exec_query_plan(qs.plan_handle) qp
    ORDER BY qs.total_elapsed_time DESC;
    
    --缓存计划所占用的 CPU 总使用率(带 SQL 文本)
    SELECT  total_cpu_time ,
            total_execution_count ,
            number_of_statements ,
            s2.text
    FROM    ( SELECT TOP 20
                        SUM(qs.total_worker_time) AS total_cpu_time ,
                        SUM(qs.execution_count) AS total_execution_count ,
                        COUNT(*) AS number_of_statements ,
                        qs.sql_handle --,
              FROM      sys.dm_exec_query_stats AS qs
              GROUP BY  qs.sql_handle
              ORDER BY  SUM(qs.total_worker_time) DESC
            ) AS stats
            CROSS APPLY sys.dm_exec_sql_text(stats.sql_handle) AS s2;
            
    --CPU 平均占用率最高的前 20 个 SQL 语句
    SELECT TOP 20
            total_worker_time / execution_count AS [Avg CPU Time] ,
            ( SELECT    SUBSTRING(text, statement_start_offset / 2,
                                  ( CASE WHEN statement_end_offset = -1
                                         THEN LEN(CONVERT(NVARCHAR(MAX), text))
                                              * 2
                                         ELSE statement_end_offset
                                    END - statement_start_offset ) / 2)
              FROM      sys.dm_exec_sql_text(sql_handle)
            ) AS query_text ,
            *
    FROM    sys.dm_exec_query_stats
    ORDER BY [Avg CPU Time] DESC;
    
    --哪个查询占用了最多的 CPU 累计使用率
    SELECT  highest_cpu_queries.plan_handle ,
            highest_cpu_queries.total_worker_time ,
            q.dbid ,
            q.objectid ,
            q.number ,
            q.encrypted ,
            q.[text]
    FROM    ( SELECT TOP 20
                        qs.plan_handle ,
                        qs.total_worker_time
              FROM      sys.dm_exec_query_stats qs
              ORDER BY  qs.total_worker_time DESC
            ) AS highest_cpu_queries
            CROSS APPLY sys.dm_exec_sql_text(plan_handle) AS q
    ORDER BY highest_cpu_queries.total_worker_time DESC;
  • 相关阅读:
    Java语法基础
    配置环境变量
    常用Dos命令
    Python 之 进程与进程池的创建和使用
    python之进程间通信
    低级别网络接口-socket的应用和粘包现象
    网络编程之模块的使用
    Python异常类型
    练习题
    python 的re模块与正则表达式
  • 原文地址:https://www.cnblogs.com/zhyue93/p/sql_state.html
Copyright © 2011-2022 走看看