天天看点

sql2005 表结构查看,生成用

--isnull函数:需要个参数,如果第一个参数为空,则赋值第二个参数。

SELECT

--空格代表as关键字

   (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 (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 'true' else 'false' end) 主键,b.name 类型,

a.length 占用字节数, COLUMNPROPERTY(a.id,a.name,'PRECISION') as 长度,

isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as 小数位数,

(case when a.isnullable=1 then 'true'else 'false' end) 允许空,

isnull(e.text,'') 默认值, isnull(g.[value],'') AS 字段说明

--a代表列集合表:为每个表和视图中的每列返回一行,并为数据库中的存储过程的每个参数返回一行

--b代表列类型表:为数据库中定义的每种系统提供的数据类型和每种用户定义的数据类型返回一行。

FROM  syscolumns  a left join systypes b

on  a.xtype=b.xusertype

--d代表对象表:在数据库中创建的每个对象(例如约束、默认值、日志、规则以及存储过程)都对应一行

inner join sysobjects d

on a.id=d.id  and  d.xtype='U' and  d.name<>'dtproperties'

--e代表e.text是默认值:包含数据库中每个视图、规则、默认值、触发器、CHECK 约束、DEFAULT 约束和存储过程的项

left join syscomments e

on a.cdefault=e.id

--g代表g.[value]是字段说明:针对当前数据库中的每个扩展属性返回一行。

left join sys.extended_properties g

on a.id=g.major_id AND a.colid = g.minor_id

where d.name = 'MenuFunction'

order by a.id,a.colorder