1. 程式人生 > >通過sql的DMV查看數據庫使用狀態

通過sql的DMV查看數據庫使用狀態

sta clas plan sed group logic RKE 耗時 tid

--數據庫隔離級別 讀未提交
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;

通過sql的DMV查看數據庫使用狀態