java 数据库 字段名 转_【转】如何得到数据库中所有表名,表字段及字段中文描述...

本文介绍了如何在 SQL Server 中查询数据表的字段信息,包括字段名、类型、标识、主键等,并展示了如何使用 `sp_addextendedproperty` 等存储过程来管理表和字段的自定义注释。通过示例代码,读者可以了解到如何查看和修改系统表的注释,以及如何添加、更新和删除表和字段的描述信息。
摘要由CSDN通过智能技术生成

最近做一个项目,客户希望可以自己选择想要查看的列表,这样就不好办了,选择列表的名字他们也想自定义,没办法这就需要查看数据表中字段,中文说明,默认标志了。在网上查了部分资料但是发现粘上去的代码都存在问题,无奈只好自己修改了一下,代码如下:

如下代码能正常运行,都是网上查找资料最后拼凑总结出来的。条件就自己加吧。网上好像也有不少类型的东西,这里留着以备不时只需!

SELECT(CASEWHENa.colorder=1THENd.NAMEELSE''END) N'表名',

a.colorder N'字段序号',

a.NAME N'字段名',

(CASEWHENcolumnproperty(a.id, a.NAME,'IsIdentity')=1THEN'√'ELSE''END) N'标识',

(CASEWHEN(SELECTCOUNT(*)FROMsysobjectsWHERE(NAMEIN(SELECTNAMEFROMsysindexesWHERE(id=a.id)AND(indidIN(SELECTindidFROMsysindexkeysWHERE(id=a.id)AND(colidIN(SELECTcolidFROMsyscolumnsWHERE(id=a.id)AND(NAME=a.NAME)))))))AND(xtype='PK'))>0THEN'√'ELSE''END) N'主键',

b.NAME N'类型',

a.length N'占用字节数',columnproperty(a.id, a.NAME,'PRECISION')ASN'长度',isnull(columnproperty(a.id, a.NAME,'Scale'),0)ASN'小数位数',

(CASEWHENa.isnullable=1THEN'√'ELSE''END) N'允许空',isnull(e.text,'') N'默认值',isnull(g. VALUE,'')ASN'字段说明'--into ##txFROMsyscolumns aLEFTJOINsystypes bONa.xtype=b.xusertypeINNERJOINsysobjects dONa.id=d.idANDd.xtype='U'ANDd.NAME<>'dtproperties'LEFTJOINsyscomments eONa.cdefault=e.idLEFTJOINsys.extended_properties gONa.id=g.major_idANDa.colid=g.minor_idORDERBYobject_name(a.id), a.colorder

sysproperties表的详解: 1、表名:sqlserver的注释表,每个数据库都有,包括表和字段的注释,表或者列的注释都会存储,没有注释不存储。 2、字段:   id:表的ID或者是列的ID   smallid:列的顺序,排序用   type:3 表,4字段,可能还有约束什么的,还没有测试出   name:统一的MS_Description   value:描述

如需修改(转载部分)

如果需要更新 此表的 内容 需要 开启 [允许对系统目录直接进行修改] ,否则 改不了 系统表

如果 不开启 此 功能  ,那么也可以 使用 存储过程[sp_addextendedproperty] 来 添加\更新\删除 表和字段的描述 用法如下

--创建表Create Table 表(a1 varchar(10),a2 char(2))

--为表 添加 描述信息 : 第二个参数为 [描述] 第六个参数为 [表名]EXECUTE sp_addextendedproperty N'MS_Description', '人员信息表', N'user', N'dbo', N'table', N'表', NULL, NULL

--为表 更新 描述信息 : 第二个参数为 [描述]  第六个参数为 [表名]EXECUTE sp_updateextendedproperty 'MS_Description',N'adsfasfdas', N'user', N'dbo', N'table', N'表', NULL, NULL

--为表 删除 描述信息 : 第五个参数为 [表名]EXEC sp_dropextendedproperty 'MS_Description',N'user', N'dbo', N'table', N'表', NULL, NULL

--字段的 添加 更新 删除 方法 --为 字段a1 添加 描述信息: 第二个参数为 [描述] 第六个参数为 [表名] 第八个参数为 [字段名称] EXECUTE sp_addextendedproperty N'MS_Description', '姓名', N'user', N'dbo', N'table', N'表', N'column', N'a1'

--更新 字段 a1 的描述属性:第二个参数为 [描述] 第六个参数为 [表名] 第八个参数为 [字段名称] EXEC sp_updateextendedproperty 'MS_Description','字段1dd','user',dbo,'table','表','column',N'a1'

--删除 字段 a1 的描述属性:第五个参数为 [表名] 第七个参数为 [字段名称] EXEC sp_dropextendedproperty 'MS_Description','user',dbo,'table','表','column','a1'

--删除测试Drop Table 表

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值