繁体   English   中英

sql server 中 INFORMATION_SCHEMA 的等效查询

[英]Equivalent query in sql server for INFORMATION_SCHEMA

我正在处理一个页面,我们需要在其中直观地比较两个数据库中同一个表的架构——一个在 sql server 中,另一个在 mysql.I 中。我还必须包括索引。

现在 mysql 查询显示信息和索引 -

select column_name,column_type,table_name,column_key 
  from INFORMATION_SCHEMA.COLUMNS where table_name = 'tbl_ClientDN'

但是对于 sql server,相同的查询不返回索引-

 select * from INFORMATION_SCHEMA.COLUMNS where table_name = 'tbl_ClientDN'

所以我需要查询来组合 -

 sp_helpindex 'tbl_ClientDN'

如何获取在 mssql 查询中显示索引的 column_key。 有什么建议吗?

远离INFORMATION_SCHEMA.COLUMNS ,尤其是索引,因为过滤索引和包含的列之类的东西不是定义的一部分。 我在这里更详细地讨论这个:

您想为此使用sys.indexessys.index_columns 例如:

DECLARE @tablename NVARCHAR(512) = 'dbo.tbl_ClientDN';

SELECT
    [Index]  = i.name,
    [Column] = c.Name, 
    [Type]   = i.type_desc,
    PK = i.is_primary_key,
    [Unique] = i.is_unique,
    [Unique Constraint] = i.is_unique_constraint,
    [DESC] = ic.is_descending_key,
    [INCLUDE] = ic.is_included_column,
    [Filtered] = i.filter_definition -- only for SQL Server 2008+
FROM
    sys.indexes AS i 
INNER JOIN 
    sys.index_columns AS ic 
    ON i.[object_id] = ic.[object_id] 
    AND i.index_id = ic.index_id
INNER JOIN 
    sys.columns c
    ON ic.column_id = c.column_id
    AND ic.[object_id] = c.[object_id]
WHERE 
    i.[object_id] = OBJECT_ID(@tablename)
ORDER BY [Index], ic.index_column_id;

如果您想一次对所有表执行此操作,则进行简单更改:

SELECT
    [Table] = QUOTENAME(OBJECT_SCHEMA_NAME(i.[object_id]))
      + '.' + QUOTENAME(OBJECT_NAME(i.[object_id])),
    [Index]  = i.name,
    [Column] = c.Name, 
    [Type]   = i.type_desc,
    PK = i.is_primary_key,
    [Unique] = i.is_unique,
    [Unique Constraint] = i.is_unique_constraint,
    [DESC] = ic.is_descending_key,
    [INCLUDE] = ic.is_included_column,
    [Filtered] = i.filter_definition -- only for SQL Server 2008+
FROM
    sys.indexes AS i 
INNER JOIN 
    sys.index_columns AS ic 
    ON i.[object_id] = ic.[object_id] 
    AND i.index_id = ic.index_id
INNER JOIN 
    sys.columns c
    ON ic.column_id = c.column_id
    AND ic.[object_id] = c.[object_id]
ORDER BY [Table], [Index], ic.index_column_id;

主题sys.indexessys.index_columns 中提供了更多信息。

您可能还想看看 Kimberley L. Tripp 的sp_helpindex2


编辑

总的来说,我同意@BrianWhite 的评论。 如果您正在为此付出任何努力,那么您应该为此使用工具,而不是重新发明轮子并尝试自己编写。 就时间而言,您可能已经花费了一个好的工具的成本来解决这个查询的问题。 请阅读这篇文章:

也许你在追求sp_help

http://msdn.microsoft.com/en-us/library/ms187335.aspx

只需输入

sp_help myTableName

应该给你你想要的所有数据。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM