SQL Serverのメモリ使用量が高すぎて、メモリ使用量が高く、パフォーマンスに影響を与えるsql文を検索

1000 ワード

SQL Serverが使用するリソースが高すぎて、コンピュータを再起動しても問題が解決できない場合がある場合は、次の文でSQL文の問題をチェックすることをお勧めします.
当日の問題が増加した場合{order by last_worker_time desc、今日どのsql実行に問題が発生したかを見たい}
SELECT s2.dbid, 
s1.sql_handle, 
(SELECT TOP 1 SUBSTRING(s2.text,statement_start_offset / 2+1 , 
( (CASE WHEN statement_end_offset = -1 
THEN (LEN(CONVERT(nvarchar(max),s2.text)) * 2) 
ELSE statement_end_offset END) - statement_start_offset) / 2+1)) AS sql_statement,
execution_count, 
plan_generation_num, 
last_execution_time, 
total_worker_time, 
last_worker_time, 
min_worker_time, 
max_worker_time,
total_physical_reads, 
last_physical_reads, 
min_physical_reads, 
max_physical_reads, 
total_logical_writes, 
last_logical_writes, 
min_logical_writes, 
max_logical_writes 
FROM sys.dm_exec_query_stats AS s1 
CROSS APPLY sys.dm_exec_sql_text(sql_handle) AS s2 
WHERE s2.objectid is null 
ORDER BY last_worker_time desc,s1.sql_handle, s1.statement_start_offset, s1.statement_end_offset; 

チャート_worker_timeは実行ミリ秒数