獲取SQL SERVER2012的數據庫表結構



SELECT
 (case when a.colorder=1 then d.name else '' end) N'表名',
a.colorder N'字段序號',
a.name N'字段名',
 (case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end) N'標識',
 (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) N'主鍵',
b.name N'類型',
a.length N'佔用字節數',
COLUMNPROPERTY(a.id,a.name,'PRECISION') as N'長度',
isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as N'小數位數',
 (case when a.isnullable=1 then '√'else '' end) N'允許空',
isnull(e.text,'') N'默認值',
isnull(g.[value],'') AS N'字段說明'
into ##tx

 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.id AND a.colid = g.smallid 
 on a.id=g.major_id AND a.colid = g.major_id
 order by object_name(a.id),a.colorder

 declare @db varchar(30),@sql varchar(3000)
 set @db=db_name()
 set @sql='exec master.dbo.xp_cmdshell ''bcp ..dbo.##tx out c:\'+@db+'_exp.xls -c -Usa -P '''
 --print @sql
 exec(@sql)

 select * from ##tx

發佈了176 篇原創文章 · 獲贊 129 · 訪問量 86萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章