SQL2008数据库结构查询SQL

本文介绍了一段SQL查询语句,该语句用于从数据库中获取指定表的所有字段信息,包括字段名称、数据类型、是否为主键等属性。通过此查询可以快速了解表结构。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SELECT TOP 100 PERCENT
a.id,CASE WHEN a.colorder = 1 THEN d.name ELSE '' END AS 表名,
a.colorder AS 字段序号,
a.name AS 字段名,
 CASE WHEN COLUMNPROPERTY(a.id,a.name, 'IsIdentity') = 1 THEN '√' ELSE '' END AS 标识,
 CASE WHEN EXISTS(SELECT 1FROM dbo.sysindexes si INNER JOIN dbo.sysindexkeys sik ON si.id = sik.id AND si.indid = sik.indid INNER JOIN dbo.syscolumns sc ON sc.id = sik.id AND sc.colid = sik.colid INNER JOIN dbo.sysobjects so ON so.name = si.name AND so.xtype = 'PK' WHERE sc.id = a.id AND sc.colid = a.colid) THEN '√' ELSE '' END AS 主键,
 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 默认值,
 d.crdate AS 创建时间,
 CASE WHEN a.colorder = 1 THEN d.refdate ELSE NULL END AS 更改时间
 FROM dbo.syscolumns a
 LEFT OUTER JOIN dbo.systypes b ON a.xtype = b.xusertype
 INNER JOIN dbo.sysobjects d ON a.id = d.id AND d.xtype = 'U' AND d.status >= 0
 LEFT OUTER JOIN dbo.syscomments e ON a.cdefault = e.id
 ORDER BY d.name, a.colorder

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

疾风铸境

提供工作中碰到的和研究过的技术

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值