不知道你要怎样的结构?
如果是建数据库的,就用生成SQL脚本功能来生成所有的数据库结构创建SQL语句如果你要显示的结果,你就用花点时间,利用用sysobject,syscolumns表来达到你要的效果

解决方案 »

  1.   

    转贴拷到查询分析器运行一下,:)SELECT 
    (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 '√' else '' 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 '√'else '' end) 允许空,
    isnull(e.text,'') 默认值,
    isnull(g.[value],'') AS 字段说明 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
      

  2.   

    简化一下:
    select object_name(id) as 表名,a.name as 字段名,b.name as 数据类型,a.length 占用字节数,a.prec as 长度,a.scale as 小数位数
    from syscolumns a
    left join systypes b on a.xusertype=b.xusertype
    where objectproperty(id,'IsUserTable')=1