我正在寻找SQL Server中MYSQL的“显示索引”的替代方法。有人可以帮忙吗?
显示索引dbname.tablename;
答案 0 :(得分:0)
您可以使用sp_helpindex获取表上的索引
EXEC sp_helpindex 'table_name';
使用@marc_s的查询[1],您可以创建视图
create view show_indexes as
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.index_column_id;
然后您可以将其与select一起使用
select * from show_indexes where table_name = ...