为了账号安全,请及时绑定邮箱和手机立即绑定

SQL Server DB中所有索引和索引列的列表

SQL Server DB中所有索引和索引列的列表

收到一只叮咚 2019-08-29 08:27:24
SQL Server DB中所有索引和索引列的列表如何获取SQL Server 2005+中所有索引和索引列的列表?我能得到的最接近的是:select s.name, t.name, i.name, c.name from sys.tables tinner join sys.schemas s on t.schema_id = s.schema_idinner join sys.indexes i on i.object_id = t.object_idinner join sys.index_columns ic on ic.object_id = t.object_idinner join sys.columns c on c.object_id = t.object_id and        ic.column_id = c.column_idwhere 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 > 0order by ic.key_ordinal这不是我想要的。我想要的是,列出所有用户定义的索引(这意味着没有支持唯一约束和主键的索引)与所有列(按它们在索引定义中的显示方式排序)加上尽可能多的元数据。
查看完整描述

3 回答

?
呼如林

TA贡献1798条经验 获得超3个赞

您可以使用它sp_helpindex来查看一个表的所有索引。

EXEC sys.sp_helpindex @objname = N'User' -- nvarchar(77)

对于所有索引,您可以遍历sys.objects以获取每个表的所有索引。


查看完整回答
反对 回复 2019-08-29
  • 3 回答
  • 0 关注
  • 706 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信