我需要在SQL server上编写一个查询,以获取特定表中的列列表、其关联的数据类型(带长度)以及它们是否不为null.我已经做到了这一点.
但现在,我还需要在同一个表中,针对一列-TRUE
,如果该列是主键.
我该怎么做?
我的预期输出是:
Column name | Data type | Length | isnull | Pk
我需要在SQL server上编写一个查询,以获取特定表中的列列表、其关联的数据类型(带长度)以及它们是否不为null.我已经做到了这一点.
但现在,我还需要在同一个表中,针对一列-TRUE
,如果该列是主键.
我该怎么做?
我的预期输出是:
Column name | Data type | Length | isnull | Pk
为了避免某些列的行重复,请使用用户类型id而不是系统类型id.
SELECT
c.name 'Column Name',
t.Name 'Data type',
c.max_length 'Max Length',
c.precision ,
c.scale ,
c.is_nullable,
ISNULL(i.is_primary_key, 0) 'Primary Key'
FROM
sys.columns c
INNER JOIN
sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN
sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN
sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
c.object_id = OBJECT_ID('YourTableName')
只需将YourTableName
替换为实际的表名即可——适用于SQL Server 2005及更高版本.
如果使用的是模式,请将YourTableName
替换为YourSchemaName.YourTableName
,其中YourSchemaName
是实际的模式名,YourTableName
是实际的表名.