set statistics time onをSQL文の前に実行します。
例えば
set statistics time on; go select * from saleslt.Customer; goといったSQL文を実行すると
SQL Server parse and compile time: CPU time = 0 ms, elapsed time = 1 ms. (847 row(s) affected) SQL Server Execution Times: CPU time = 16 ms, elapsed time = 8 ms.といった実行時間の情報が得られます。
また、平均CPUに基づいて上位N位のSQL文を取得したい場合には、動的管理ビュー「sys.dm_exec_query_stats」を使います。
例えば上位5位までのSQL文を取得したい場合には
SELECT TOP 5 query_stats.query_hash AS "Query Hash", SUM(query_stats.total_worker_time) / SUM(query_stats.execution_count) AS "Avg CPU Time", MIN(query_stats.statement_text) AS "Statement Text" FROM (SELECT QS.*, SUBSTRING(ST.text, (QS.statement_start_offset/2) + 1, ((CASE statement_end_offset WHEN -1 THEN DATALENGTH(st.text) ELSE QS.statement_end_offset END - QS.statement_start_offset)/2) + 1) AS statement_text FROM sys.dm_exec_query_stats AS QS CROSS APPLY sys.dm_exec_sql_text(QS.sql_handle) as ST) as query_stats GROUP BY query_stats.query_hash ORDER BY 2 DESC; GOといったSQL文を実行します。
なお、残念ながらこれらはAzure SQL Datawarehouseでは使用できないようです。
参考:https://technet.microsoft.com/ja-jp/library/gg457940.aspx
0 件のコメント:
コメントを投稿
注: コメントを投稿できるのは、このブログのメンバーだけです。