Как мне получить список всех столбцов индекса и индекса в 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
Это не совсем то, что я хочу. Я хочу, чтобы перечислять все определяемые пользователем индексы (что означает отсутствие индексов, которые поддерживают уникальные ограничения и первичные ключи) со всеми столбцами (упорядоченными по тому, как они появляются в определении индекса), плюс как можно больше метаданных.