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

来源:asp之家 时间:2012-01-05 18:56:44 

在网上查了部分资料但是发现粘上去的代码都存在问题,无奈只好自己修改了一下,代码如下:

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

代码如下:


SELECT
(case when a.colorder=1 then d.name else '' end) N'表名',
a.colorder N'字段序号',
a.name N'字段名',
(case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end) N'标识',
(case when (SELECT count(*)
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) N'主键',
b.name N'类型',
a.length N'占用字节数',
COLUMNPROPERTY(a.id,a.name,'PRECISION') as N'长度',
isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as N'小数位数',
(case when a.isnullable=1 then '√'else '' end) N'允许空',
isnull(e.text,'') N'默认值',
isnull(g.[value],'') AS N'字段说明'
--into ##tx
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
order by object_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 表

标签:数据库,表名,sql
0
投稿

猜你喜欢

  • Python爬虫实战之虎牙视频爬取附源码

    2021-04-02 01:23:27
  • python实现杨氏矩阵查找

    2021-09-28 15:03:26
  • 手把手教你使用Python创建微信机器人

    2022-02-11 14:12:29
  • Python cookbook(数据结构与算法)筛选及提取序列中元素的方法

    2023-04-27 19:46:34
  • php在windows环境下获得cpu内存实时使用率(推荐)

    2023-11-15 04:44:23
  • 分享6 个值得收藏的 Python 代码

    2022-12-31 05:09:57
  • OpenCV实战之实现手势虚拟缩放效果

    2023-04-06 12:51:09
  • VSCode插件安装完成后的配置详解

    2022-02-16 00:36:34
  • python mysql断开重连的实现方法

    2024-01-24 01:20:26
  • python数据预处理之数据标准化的几种处理方式

    2022-12-14 11:48:29
  • 基于MTCNN/TensorFlow实现人脸检测

    2021-07-05 23:51:19
  • python替换字符串中的子串图文步骤

    2021-06-23 22:02:47
  • Python使用functools模块中的partial函数生成偏函数

    2024-01-01 21:26:47
  • PHP邮箱验证示例教程

    2023-06-20 12:01:47
  • python实现快递价格查询系统

    2023-02-06 11:20:27
  • 排序与检索

    2008-05-18 13:09:00
  • SQL Server 2005通用分页存储过程及多表联接应用

    2024-01-13 22:39:31
  • Python抓取通过Ajax加载数据的示例

    2023-12-09 21:28:38
  • Python实现按特定格式对文件进行读写的方法示例

    2022-06-07 22:59:57
  • asp使用正则自动解析图片地址并保存

    2007-08-17 11:29:00
  • asp之家 网络编程 m.aspxhome.com