SQL Serverでは、SET STATISTICS IO
を使用できます T-SQLステートメントによって生成されたディスクアクティビティの量に関する詳細情報を生成するステートメント。
SSMSやAzureDataStudioなどのグラフィカルツールでは、この情報をメッセージで表示できます。 タブ。
例
これがデモンストレーションの簡単な例です。
SET STATISTICS IO ON;
SELECT
c.CityName,
s.StateProvinceName AS State,
c.LatestRecordedPopulation AS Population
FROM Application.Cities c
INNER JOIN Application.StateProvinces s
ON c.StateProvinceID = s.StateProvinceID
WHERE c.LatestRecordedPopulation > 2000000
ORDER BY c.LatestRecordedPopulation DESC;
最初は、通常どおりクエリ結果が表示される可能性があります。
STATISTICS IO
の出力を表示するには 、メッセージをクリックします タブ:
この例はAzureDataStudioで行われ、SSMSを使用する場合と同じプロセスです。ただし、使用する必要のある実際の手順は、SQLServerへの接続に使用するツールによって異なる場合があります。
以下は、STATISTICS IO
のコピーです。 上のスクリーンショットからのメッセージ:
(6 rows affected) Table 'Worktable'. Scan count 0, logical reads 0, physical reads 0, page server reads 0, read-ahead reads 0, page server read-ahead reads 0, lob logical reads 0, lob physical reads 0, lob page server reads 0, lob read-ahead reads 0, lob page server read-ahead reads 0. Table 'Workfile'. Scan count 0, logical reads 0, physical reads 0, page server reads 0, read-ahead reads 0, page server read-ahead reads 0, lob logical reads 0, lob physical reads 0, lob page server reads 0, lob read-ahead reads 0, lob page server read-ahead reads 0. Table 'StateProvinces'. Scan count 1, logical reads 2, physical reads 0, page server reads 0, read-ahead reads 0, page server read-ahead reads 0, lob logical reads 0, lob physical reads 0, lob page server reads 0, lob read-ahead reads 0, lob page server read-ahead reads 0. Table 'Cities'. Scan count 1, logical reads 497, physical reads 0, page server reads 0, read-ahead reads 0, page server read-ahead reads 0, lob logical reads 0, lob physical reads 0, lob page server reads 0, lob read-ahead reads 0, lob page server read-ahead reads 0. Total execution time: 00:00:00.027
オフにする方法
STATISTICS IO
の設定 ON
へ オフになるまで、後続のすべてのT-SQLステートメントに影響します。
オフにするには、OFF
を使用してもう一度実行します。 ON
の代わりに :
SET STATISTICS IO OFF;