SELECT
表名=d.name,--case when a.colorder=1 then d.name else '' end,
字段序号=a.colorder,
字段名=a.name,
标识=case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end,
主键=case when exists(SELECT 1 FROM sysobjects where xtype='PK' and name in (
SELECT name FROM sysindexes WHERE indid in(
SELECT indid FROM sysindexkeys WHERE id = a.id AND colid=a.colid
))) then '√' else '' end,
类型=b.name,
占用字节数=a.length,
长度=COLUMNPROPERTY(a.id,a.name,'PRECISION'),
小数位数=isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0),
允许空=case when a.isnullable=1 then '√'else '' end,
默认值=isnull(e.text,''),
字段说明=isnull(g.[value],'')
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 sysproperties g on a.id=g.id and a.colid=g.smallid
order by a.id,a.colorder
这是在网上转载的。(http://www.alixixi.com/Dev/DB/MSSQL/2007/2007020916013.html)
可以用上面的语句来创建一个视图,这样在数据库新增了一个表的时候,就能及时的得到准确的结构信息。这个视图对于开发中遇到表特别多,而程序又要求动态显示结果的时候非常有用。比如:要在一个页面上动态不同表的信息时,可以用这个视图里面的内容,输出要显示的列名,中文名(可以用字段说明,这要求在建表的时候填写描述)。这样的话,程序将会少写很多代码,而且在要对页面调整的时候也不用将很多的页面都进行修改。