利用sysobjects和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 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
      

  2.   

    --查詢導出
    EXEC master..xp_cmdshell 'bcp "SELECT class_no,kind_no,cn_name FROM new_ks.dbo.kind ORDER BY 1,2" queryout "e:\TX1.txt" -c -q -S"sprogram" -U"develop" -P"12345"'
    --直接導出
    EXEC master..xp_cmdshell 'bcp new_ks.dbo.class out "e:\TX3.txt" -c -S"sprogram" -U"develop" -P"12345"'EXEC master..xp_cmdshell 'bcp hdh.dbo.tabx out "e:\TX30.txt" -c -S"ks052" -U"huang" -P"huang"'