查sqlserver表结构说明的方法
admin
2023-05-24 05:42:21
0

一、查出某个库的所有表名

USE database_name
GO

SELECT tab.name        AS tableName
FROM   sys.columns col
       INNER JOIN sys.tables tab
               ON col.object_id = tab.object_id
       LEFT JOIN sys.extended_properties per
              ON col.column_id = per.minor_id
                 AND per.major_id = tab.object_id
       INNER JOIN sys.types type
               ON col.user_type_id = type.user_type_id
group by tab.name 
ORDER  BY tab.name

二、查出某个库的所有字段说明

USE database_name
GO

SELECT tab.name        AS tableName,
       col.name        AS column_name,
       per.value       AS column_comment,
       col.is_identity AS column_key,
       type.name       AS data_type,
   col.max_length  AS column_length
FROM   sys.columns col
       INNER JOIN sys.tables tab
               ON col.object_id = tab.object_id
       LEFT JOIN sys.extended_properties per
              ON col.column_id = per.minor_id
                 AND per.major_id = tab.object_id
       INNER JOIN sys.types type
               ON col.user_type_id = type.user_type_id
ORDER  BY tab.name,
          col.is_identity DESC

二、查出某个库的所有字段说明(查出数据详细格式化版)

USE database_name
GO
SELECT     
        表名=case when a.colorder=1 then d.name else '' end,    
        表说明=case when a.colorder=1 then isnull(f.value,'') 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 sys.extended_properties g on a.id=g.major_id AND a.colid = g.minor_id    
        left join sys.extended_properties f on d.id=f.major_id and f.minor_id=0    
     order by a.id,a.colorder


相关内容

热门资讯

机票多出“民航发展基金”?业内... 近日有网友发布消息称,在购买机票时发现购票款明细中,除了机票本身以及燃油附加费外,还有一笔名为“民航...
重庆云潼科技取得串扰抑制驱动电... 国家知识产权局信息显示,重庆云潼科技有限公司取得一项名为“一种串扰抑制驱动电路”的专利,授权公告号C...
苏南首个用户侧构网型储能电站并... 5月14日,苏南地区首个用户侧构网型储能电站在常州经开区轨道交通产业园顺利并网。作为园区微电网项目的...
记者手记:当“硬核科技”邂逅“... 一抹溶液轻覆,白玫瑰渐染绯红。常在书本上的科学原理,在方寸实验台前化作温柔的色彩流转,映亮孩子们纯真...
原创 今... 从种子到IPO的“接力式”赋能。 在硬科技创投圈,有一个备受瞩目的行业共识:高校孵化出的顶尖技术,...
德国财长:其他国家正在改变规则... 【文/观察者网 熊超然】当地时间5月19日,七国集团(G7)成员国的财政部长和央行行长齐聚法国首都巴...
三星家电在中国大陆停售,是“外... 近来,韩国三星电子宣布停止在中国大陆销售电视、冰箱、洗衣机等全品类家电。在一些西方媒体的报道中,“外...
“宜兰女婿”蒋万安跨县市力挺,... 海峡导报综合报道 国民党宜兰县长参选人吴宗宪19日晚办首场大型造势,数千名支持者力挺。身为“宜兰女婿...
重返欧盟?“英国须付数十亿英镑... 【文/观察者网 熊超然】近期,英国政局动荡不稳,“逆转脱欧”已成为执政党工党领导层内部那场充满戏剧性...
修水龙头出水小怎么办 水龙头出水小可能有多种原因,以下是一些常见的解决方法:1. 检查水龙头滤网:拧下水龙头前端的滤网,清...