SQL Server 2005+ のすべてのインデックスとインデックス列のリストを取得するにはどうすればよいですか? 最も近いものは次のとおりです。
select s.name, t.name, i.name, c.name from sys.tables t
inner join sys.schemas s on t.schema_id = s.schema_id
inner join sys.indexes i on i.object_id = t.object_id
inner join sys.index_columns ic on ic.object_id = t.object_id
inner join sys.columns c on c.object_id = t.object_id and
ic.column_id = c.column_id
where i.index_id > 0
and i.type in (1, 2) -- clustered & nonclustered only
and i.is_primary_key = 0 -- do not include PK indexes
and i.is_unique_constraint = 0 -- do not include UQ
and i.is_disabled = 0
and i.is_hypothetical = 0
and ic.key_ordinal > 0
order by ic.key_ordinal
これはまさに私が望んでいることではありません。
私が望んでいるのは、すべてのユーザー定義インデックス (一意の制約と主キーをサポートするインデックスは除く) とすべての列 (インデックス定義での表示順) および可能な限り多くのメタデータを一覧表示することです。
ベストアンサー1
参照できる「sys」カタログ ビューはsys.indexes
と の2 つありますsys.index_columns
。
これらにより、インデックスとその列に関して必要なほぼすべての情報が得られます。
編集: このクエリはあなたが探しているものにかなり近いです:
SELECT
TableName = t.name,
IndexName = ind.name,
IndexId = ind.index_id,
ColumnId = ic.index_column_id,
ColumnName = col.name,
ind.*,
ic.*,
col.*
FROM
sys.indexes ind
INNER JOIN
sys.index_columns ic ON ind.object_id = ic.object_id and ind.index_id = ic.index_id
INNER JOIN
sys.columns col ON ic.object_id = col.object_id and ic.column_id = col.column_id
INNER JOIN
sys.tables t ON ind.object_id = t.object_id
WHERE
ind.is_primary_key = 0
AND ind.is_unique = 0
AND ind.is_unique_constraint = 0
AND t.is_ms_shipped = 0
ORDER BY
t.name, ind.name, ind.index_id, ic.is_included_column, ic.key_ordinal;