sys.query_store_query_variant (Transact-SQL)
適用対象: SQL Server 2022 (16.x)
元のパラメーター化されたクエリ (親クエリとも呼ばれます)、ディスパッチャー プラン、およびその子クエリバリアント間の親子リレーションシップに関する情報が含まれます。 このカタログ ビューでは、ディスパッチャーに関連付けられているすべてのクエリバリアントと、元のパラメーター化されたクエリを表示できます。 クエリ バリアントのquery_hash値は、sys.query_store_query カタログ ビュー内から見た値と同じになります。sys.query_store_query_variantおよびsys.query_store_runtime_stats カタログ ビューと結合すると、入力値によってのみ異なるクエリの集計リソース使用状況統計を取得できます。
列名 | データ型 | 説明 |
---|---|---|
query_variant_query_id | bigint | 主キー パラメーター化された機密性の高いクエリバリアントの ID。 |
parent_query_id | bigint | 元のパラメーター化されたクエリの ID。 |
dispatcher_plan_id | bigint | パラメーターに依存するプラン最適化ディスパッチャー プランの ID。 |
注釈
複数のクエリバリアントを 1 つのディスパッチャー プランに関連付けることができるため、クエリバリアントに属する複数のプランが存在し、最終的には親クエリの全体的なリソース使用量統計に追加されます。 クエリ バリアントのディスパッチャー プランでは、クエリ ストアでランタイム統計が生成されないため、query_store_query_variant ビューへの追加の結合が含まれていない限り、全体的な統計を収集するときに既存のクエリ ストア クエリで十分ではなくなります。
アクセス許可
VIEW DATABASE STATE 権限が必要です。
例
バリアント情報クエリ ストア表示する
SELECT
qspl.plan_type_desc AS query_plan_type,
qspl.plan_id as query_store_planid,
qspl.query_id as query_store_queryid,
qsqv.query_variant_query_id as query_store_variant_queryid,
qsqv.parent_query_id as query_store_parent_queryid,
qsqv.dispatcher_plan_id as query_store_dispatcher_planid,
OBJECT_NAME(qsq.object_id) as module_name,
qsq.query_hash,
qsqtxt.query_sql_text,
convert(xml,qspl.query_plan)as show_plan_xml,
qsrs.last_execution_time as last_execution_time,
qsrs.count_executions AS number_of_executions,
qsq.count_compiles AS number_of_compiles
FROM sys.query_store_runtime_stats AS qsrs
JOIN sys.query_store_plan AS qspl
ON qsrs.plan_id = qspl.plan_id
JOIN sys.query_store_query_variant qsqv
ON qspl.query_id = qsqv.query_variant_query_id
JOIN sys.query_store_query as qsq
ON qsqv.parent_query_id = qsq.query_id
JOIN sys.query_store_query_text AS qsqtxt
ON qsq.query_text_id = qsqtxt .query_text_id
ORDER BY qspl.query_id, qsrs.last_execution_time;
GO
ディスパッチャーとバリアントの情報クエリ ストア表示する
SELECT
qspl.plan_type_desc AS query_plan_type,
qspl.plan_id as query_store_planid,
qspl.query_id as query_store_queryid,
qsqv.query_variant_query_id as query_store_variant_queryid,
qsqv.parent_query_id as query_store_parent_queryid,
qsqv.dispatcher_plan_id as query_store_dispatcher_planid,
qsq.query_hash,
qsqtxt.query_sql_text,
CONVERT(xml,qspl.query_plan)as show_plan_xml,
qsq.count_compiles AS number_of_compiles,
qsrs.last_execution_time as last_execution_time,
qsrs.count_executions AS number_of_executions
FROM sys.query_store_query qsq
LEFT JOIN sys.query_store_query_text qsqtxt
ON qsq.query_text_id = qsqtxt.query_text_id
LEFT JOIN sys.query_store_plan qspl
ON qsq.query_id = qspl.query_id
LEFT JOIN sys.query_store_query_variant qsqv
ON qsq.query_id = qsqv.query_variant_query_id
LEFT JOIN sys.query_store_runtime_stats qsrs
ON qspl.plan_id = qsrs.plan_id
LEFT JOIN sys.query_store_runtime_stats_interval qsrsi
ON qsrs.runtime_stats_interval_id = qsrsi.runtime_stats_interval_id
WHERE qspl.plan_type = 1 or qspl.plan_type = 2
ORDER BY qspl.query_id, qsrs.last_execution_time;
GO