以下是查询sql service表中的列的属性,包括列名,类型,长度 是否是主键,是否是自增字段。
SELECT d.name N'TableName',a.colorder N'FieldNumber',a.name N'FieldName',
(case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '1'else '0' end) N'IsIdentifier',
(case when (SELECT count(*)
FROM sysobjects WHERE (name in (SELECT name FROM sysindexes
WHERE (id = a.id) AND (indid in (SELECT indid FROM sysindexkeys
WHERE (id = a.id) AND (colid in (SELECT colid FROM syscolumns
WHERE (id = a.id) AND (name = a.name))))))) AND (xtype = 'PK'))>0
then '1' else '0' end) N'IsKeyField', b.name N'FieldType',a.length N'FieldSize',
COLUMNPROPERTY(a.id,a.name,'PRECISION') as N'FieldLength',
isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as N'DecimalDigits',
(case when a.isnullable=1 then '1'else '0' end) N'AllowNull', isnull(e.text,'') N'DefaultValue',
isnull(g.[value],'') AS N'FieldDescn'
FROM syscolumns a left join systypes b on a.xtype=b.xusertype inner join sysobjects d
on a.id=d.id and d.xtype='U' and d.name<>'dtproperties' left join syscomments e on a.cdefault=e.id
left join sys.extended_properties g on a.id=g.major_id AND a.colid = g.minor_id
where d.name = '表名'
order by object_name(a.id),a.colorder