• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

sql中获取一个数据库中的所有表的名称、一个表中所有字段的名称

mysql 搞代码 4年前 (2022-01-09) 17次浏览 已收录 0个评论

文章介绍了关于SQLSERVER如何获取一个数据库中的所有表的名称、一个表中所有字段的名称 ,有需要了解的同学可参考一下。

1.查询中的所有数据库名:

代码如下复制代码
SELECT Name FROM Master..SysDatabases OR

本文来源gaodai.ma#com搞#代!码网_

DER BY Name2.

查询某个数据库中所有的表名:

代码如下复制代码
SELECT Name FROM SysObjects Where XType=’U’ ORDER BY Name3.

查询表结构信息

代码如下复制代码

SELECT (case when a.colorder=1 then d.name else null end) 表名,
a.colorder 字段序号,a.name 字段名,
(case when COLUMNPROPERTY( a.id,a.name,’IsIdentity’)=1 then ‘√’else ” end) 标识,
(case when (SELECT (*) 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 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.class and f.minor_id=0
where b.name is not null
–WHERE d.name=’要查询的表’ –如果只查询指定表,加上此条件
order by a.id,a.colorder


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:sql中获取一个数据库中的所有表的名称、一个表中所有字段的名称
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址