SQL 通过SQL语句检索字段类型、长度、主键

SQL 通过SQL语句检索字段类型、长度、主键

方式1:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
select 字段名=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))) and a.isnullable<>1 then '是' else '' end,
类型=b.name,
长度=a.length,
允许空=case when a.isnullable=1 then '是' else '' end,
默认值=isnull(e.text,'')
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 sysproperties g on a.id=g.id and a.colid=g.smallid
--left join sysproperties f on d.id=f.id and f.smallid=0
where d.name='表名'
--where d.name='表名' [ and a.name= '字段名' ]

 

方式2:

1
2
3
4
5
6
7
8
9
select
字段名=a.name,
占用字节数=a.length,
长度=COLUMNPROPERTY(a.id,a.name,'PRECISION'),
小数位数=isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0)
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.status>=0
where d.name='表名'

 

  

 

  

  

创建时间:2020.11.12  更新时间:

 

posted on   滔Roy  阅读(1407)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报

导航

点击右上角即可分享
微信分享提示