如何得到数据库中所有表名 表字段及字段中文描述

前端之家收集整理的这篇文章主要介绍了如何得到数据库中所有表名 表字段及字段中文描述前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

在网上查了部分资料但是发现粘上去的代码都存在问题,无奈只好自己修改了一下,代码如下: 如下代码能正常运行,都是网上查找资料最后拼凑总结出来的。条件就自己加吧。网上好像也有不少类型的东西,这里留着以备不时只需! @H_502_0@<div class="codetitle"><a style="CURSOR: pointer" data="17167" class="copybut" id="copybut17167" onclick="doCopy('code17167')"> 代码如下:

<div class="codebody" id="code17167"> @H_5020@SELECT @H5020@(case when a.colorder=1 then d.name else '' end) N'表名',@H5020@a.colorder N'字段序号',@H5020@a.name N'字段名',@H5020@(case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end) N'标识',@H5020@(case when (SELECT count(*) @H5020@FROM sysobjects @H5020@WHERE (name in @H5020@(SELECT name @H5020@FROM sysindexes @H5020@WHERE (id = a.id) AND (indid in @H5020@(SELECT indid @H5020@FROM sysindexkeys @H5020@WHERE (id = a.id) AND (colid in @H5020@(SELECT colid @H5020@FROM syscolumns @H5020@WHERE (id = a.id) AND (name = a.name))))))) AND @H5020@(xtype = 'PK'))>0 then '√' else '' end) N'主键',@H5020@b.name N'类型',@H5020@a.length N'占用字节数',@H5020@COLUMNPROPERTY(a.id,'PRECISION') as N'长度',@H5020@isnull(COLUMNPROPERTY(a.id,'Scale'),0) as N'小数位数',@H5020@(case when a.isnullable=1 then '√'else '' end) N'允许空',@H5020@isnull(e.text,'') N'默认值',@H5020@isnull(g.[value],'') AS N'字段说明' @H5020@--into ##tx @H5020@FROM syscolumns a left join systypes b @H5020@on a.xtype=b.xusertype @H5020@inner join sysobjects d @H5020@on a.id=d.id and d.xtype='U' and d.name<>'dtproperties' @H5020@left join syscomments e @H5020@on a.cdefault=e.id @H502_0@left join sys.extendedproperties g @H502_0@on a.id=g.major_id AND a.colid = g.minorid @H502_0@order by objectname(a.id),a.colorder @H502_0@
sysproperties表的详解: 1、表名:sqlserver的注释表,每个数据库都有,包括表和字段的注释,表或者列的注释都会存储,没有注释不存储。 @H_5020@2、字段: @H5020@id:表的ID或者是列的ID @H5020@smallid:列的顺序,排序用 @H5020@type:3 表,4字段,可能还有约束什么的,还没有测试出 @H502_0@name:统一的MSDescription @H502_0@value:描述 如需修改(转载部分) 如果需要更新 此表的 内容 需要 开启 [允许对系统目录直接进行修改],否则 改不了 系统表 @H_5020@@H502_0@如果 不开启 此 功能,那么也可以 使用 存储过程[sp_addextendedproperty] 来 添加\更新\删除 表和字段的描述 用法如下 --创建表 @H_502_0@Create Table 表(a1 varchar(10),a2 char(2)) --为表 添加 描述信息 : 第二个参数为 [描述] 第六个参数为 [表名] @H_502_0@EXECUTE sp_addextendedproperty N'MSDescription','人员信息表',N'user',N'dbo',N'table',N'表',NULL,NULL --为表 更新 描述信息 : 第二个参数为 [描述] 第六个参数为 [表名] @H502_0@EXECUTE sp_updateextendedproperty 'MS_Description',N'adsfasfdas',NULL --为表 删除 描述信息 : 第五个参数为 [表名] @H_502_0@EXEC sp_dropextendedproperty 'MS_Description',NULL --字段的 添加 更新 删除 方法 @H_502_0@--为 字段a1 添加 描述信息: 第二个参数为 [描述] 第六个参数为 [表名] 第八个参数为 [字段名称] @H_502_0@EXECUTE sp_addextendedproperty N'MS_Description','姓名',N'column',N'a1' --更新 字段 a1 的描述属性:第二个参数为 [描述] 第六个参数为 [表名] 第八个参数为 [字段名称] @H_502_0@EXEC sp_updateextendedproperty 'MS_Description','字段1dd','user',dbo,'table','表','column',N'a1' --删除 字段 a1 的描述属性:第五个参数为 [表名] 第七个参数为 [字段名称] @H_502_0@EXEC sp_dropextendedproperty 'MS_Description','a1' --删除测试 @H_502_0@Drop Table 表

猜你在找的MsSQL相关文章