SQL语句查询数据库所有表和所有字段的详细信息(包括表描述和字段描述)

复制代码
select (case
            when a.colorder = 1 then
                ddd.value
            else
                ''
        end
       )                                                as "表名(中文)" --如果表名相同就返回空  
     , (case
            when a.colorder = 1 then
                d.name
            else
                ''
        end
       )                                                as 表名       --如果表名相同就返回空  
     , (case
            when a.colorder = 1 then
                ddd.value
            else
                ''
        end
       )                                                as 表说明      --如果表名相同就返回空  
     , a.colorder                                       as 字段序号
     , a.name                                           as 字段名
     , (case
            when columnproperty(a.id, a.name, 'IsIdentity') = 1 then
                ''
            else
                ''
        end
       )                                                as 是否自增标识
     , (case
            when
            (
                select count(*)
                from sys.sysobjects --查询主键  
                where (name in
                       (
                           select name
                           from sys.sysindexes
                           where (id = a.id)
                                 and (indid in
                                      (
                                          select indid
                                          from sys.sysindexkeys
                                          where (id = a.id)
                                                and (colid in
                                                     (
                                                         select colid from sys.syscolumns where (id = a.id) and (name = a.name)
                                                     )
                                                    )
                                      )
                                     )
                       )
                      )
                      and (xtype = 'PK')
            ) > 0 then
                ''
            else
                ''
        end
       )                                                as 主键       --查询主键END  
     , b.name                                           as 类型
     , a.length                                         as 占用字节数
     , columnproperty(a.id, a.name, 'PRECISION')        as 长度
     , isnull(columnproperty(a.id, a.name, 'Scale'), 0) as 小数位数
     , (case
            when a.isnullable = 1 then
                ''
            else
                ''
        end
       )                                                as 允许空
     , isnull(e.text, '')                               as 默认值
     , isnull(g.value, '')                              as 字段说明
from sys.syscolumns                   a
    left join sys.systypes            b
        on a.xtype = b.xusertype
    inner join sys.sysobjects         d
        on a.id = d.id
           and d.xtype = 'U'
           and d.name <> 'dtproperties'
    left outer join
    (
        select major_id
             , value
        from sys.extended_properties
        where name = 'MS_Description'
              and minor_id = 0
    )                                 as ddd
        on a.id = ddd.major_id
    left join sys.syscomments         e
        on a.cdefault = e.id
    left join sys.extended_properties g
        on a.id = g.major_id
           and a.colid = g.minor_id
order by a.id
       , a.colorder;
复制代码

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
ALTER PROC [dbo].[sp_helpremark]     
       
@TABLE_NAME VARCHAR(50)     
       
AS     
       
 
SELECT  
 (case when a.colorder=1 then ddd.value else '' end) as "表名(中文)",--如果表名相同就返回空 
 (case when a.colorder=1 then d.name else '' end) as 表名,--如果表名相同就返回空 
 (case when a.colorder=1 then ddd.value else '' end) as 表说明,--如果表名相同就返回空 
     a.colorder as 字段序号, 
     a.name as 字段名, 
     (case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end) as 是否自增标识, 
     (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) as 主键,--查询主键END 
 b.name as 类型, 
 a.length as 占用字节数, 
 COLUMNPROPERTY(a.id,a.name,'PRECISION') as  长度, 
 isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as 小数位数, 
 (case when a.isnullable=1 then '√'else '' end) as 允许空, 
 isnull(e.text,'') as 默认值,
 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 OUTER JOIN( SELECT major_id, value
     FROM sys.extended_properties
     WHERE name='MS_Description' AND minor_id = 0)
    as ddd  ON a.id = ddd.major_id
 left join syscomments e 
 on a.cdefault=e.id 
 left join sys.extended_properties g 
 on a.id=g.major_id AND a.colid = g.minor_id  where d.name like '%'+@TABLE_NAME+'%'
 order by a.id,a.colorder

  

posted @   未风  阅读(5220)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
历史上的今天:
2017-10-26 外部数据库驱动程序XX中的意外错误
点击右上角即可分享
微信分享提示