甩掉数据字典,让Sql Server数据库也来一个自描述
2008-09-10 11:35
316 查看
我们学、用.NET的都知道,程序集(Assembly)的一个很大的优点就是它有元数据,可以“自描述”。在我们体验这种优势的同时,我们是否想过什么时候数据库中的信息也是自描述的该多好?
我想Sql Server中有扩展属性,并且Sql Server的“元数据”,其实都可以通过一些系统表、系统视图等中查到,所以我想为何不利用一下这些扩展属性,让数据库中的表、视图、字段等也来一个自我描述,省去手工维护那些Excel格式之类的外部数据字典的麻烦?
以下是我的初步实践,可能并不完美,希望可以给大家一个抛砖引玉的效果就好。
首先,对于数据表中字段,因为在你用SSMS给一个表添加字段的时候,就有一个属性可以填写一个描述,因此获取这些描述信息自然是非常简单的,我实现了如下视图:
CREATE VIEW [dbo].[DOC_vwColumns]
AS
-- 数据表字段的说明
-- 作者:RickyLin, http://Ricky81317.cnblogs.com/
SELECT T.Table_Name, C.Column_Name, C.Data_Type, C.Character_Maximum_Length, C.Is_Nullable, P.[Value] AS ColumnDescription
FROM INFORMATION_SCHEMA.Tables T
INNER JOIN INFORMATION_SCHEMA.Columns C ON C.Table_Name = T.Table_Name
LEFT JOIN Sys.Extended_Properties P ON P.Major_ID = Object_ID(T.Table_Name) AND P.Minor_ID = C.Ordinal_Position AND P.[Name] = 'MS_Description'
WHERE T.Table_Type = 'BASE TABLE'
--ORDER BY T.Table_Name, C.Ordinal_Position
通过查询这个视图,就可以得到各个数据表中的字段的说明,而且因为是一个视图,所以可以通过添加Where条件,从这个视图中筛选出你需要的个别表的字段信息
对于数据库中的表、视图、存储过程、函数等,在你创建的时候,并没有一个明显的可以填写“描述”的地方,但是,当你创建这些数据库对象完成之后,可以现在SSMS中选中这个对象,然后右键-->属性,就可以在属性对话框的左边的找到“扩展属性”,然后在扩展属性中增加一条,用来描述对象的信息。我是使用ObjectDescription这个名字添加的扩展属性,添加完成之后,点击确定。然后可以利用以下视图进行查询:
CREATE VIEW [dbo].[DOC_vwObjects]
AS
-- 数据库对象的说明
-- 作者:RickyLin, http://Ricky81317.cnblogs.com/
SELECT T.[Object_ID] AS ObjectID, T.[Name] AS ObjectName, T.[Type] AS ObjectType, P.[Value] AS ObjectDescription
FROM Sys.Objects T
LEFT JOIN Sys.extended_properties P ON P.Major_ID = T.[Object_ID]
WHERE P.[Name] = 'ObjectDescription'
是不是很简单?
通过这种方法,可以为我们的数据库建立起一个自描述的方式,可以用比较方便的方法,维护和查询说明信息,并且在无论我们备份还是分离数据库,这些描述信息都是在数据库里面随着数据库文件走(这也是自描述的优势啊),不需要额外的附带着其他文件性质说明文档。就算要一份最新的Excel格式的数据库字典,也只需要查询出结果,然后复制、粘贴到Excel里面就行了。
我想Sql Server中有扩展属性,并且Sql Server的“元数据”,其实都可以通过一些系统表、系统视图等中查到,所以我想为何不利用一下这些扩展属性,让数据库中的表、视图、字段等也来一个自我描述,省去手工维护那些Excel格式之类的外部数据字典的麻烦?
以下是我的初步实践,可能并不完美,希望可以给大家一个抛砖引玉的效果就好。
首先,对于数据表中字段,因为在你用SSMS给一个表添加字段的时候,就有一个属性可以填写一个描述,因此获取这些描述信息自然是非常简单的,我实现了如下视图:
CREATE VIEW [dbo].[DOC_vwColumns]
AS
-- 数据表字段的说明
-- 作者:RickyLin, http://Ricky81317.cnblogs.com/
SELECT T.Table_Name, C.Column_Name, C.Data_Type, C.Character_Maximum_Length, C.Is_Nullable, P.[Value] AS ColumnDescription
FROM INFORMATION_SCHEMA.Tables T
INNER JOIN INFORMATION_SCHEMA.Columns C ON C.Table_Name = T.Table_Name
LEFT JOIN Sys.Extended_Properties P ON P.Major_ID = Object_ID(T.Table_Name) AND P.Minor_ID = C.Ordinal_Position AND P.[Name] = 'MS_Description'
WHERE T.Table_Type = 'BASE TABLE'
--ORDER BY T.Table_Name, C.Ordinal_Position
通过查询这个视图,就可以得到各个数据表中的字段的说明,而且因为是一个视图,所以可以通过添加Where条件,从这个视图中筛选出你需要的个别表的字段信息
对于数据库中的表、视图、存储过程、函数等,在你创建的时候,并没有一个明显的可以填写“描述”的地方,但是,当你创建这些数据库对象完成之后,可以现在SSMS中选中这个对象,然后右键-->属性,就可以在属性对话框的左边的找到“扩展属性”,然后在扩展属性中增加一条,用来描述对象的信息。我是使用ObjectDescription这个名字添加的扩展属性,添加完成之后,点击确定。然后可以利用以下视图进行查询:
CREATE VIEW [dbo].[DOC_vwObjects]
AS
-- 数据库对象的说明
-- 作者:RickyLin, http://Ricky81317.cnblogs.com/
SELECT T.[Object_ID] AS ObjectID, T.[Name] AS ObjectName, T.[Type] AS ObjectType, P.[Value] AS ObjectDescription
FROM Sys.Objects T
LEFT JOIN Sys.extended_properties P ON P.Major_ID = T.[Object_ID]
WHERE P.[Name] = 'ObjectDescription'
是不是很简单?
通过这种方法,可以为我们的数据库建立起一个自描述的方式,可以用比较方便的方法,维护和查询说明信息,并且在无论我们备份还是分离数据库,这些描述信息都是在数据库里面随着数据库文件走(这也是自描述的优势啊),不需要额外的附带着其他文件性质说明文档。就算要一份最新的Excel格式的数据库字典,也只需要查询出结果,然后复制、粘贴到Excel里面就行了。
相关文章推荐
- [转]甩掉数据字典,让Sql Server数据库也来一个自描述
- 甩掉数据字典,让Sql Server数据库也来一个自描述
- 一个单词单词字母交换,可得另一个单词,如army->mary,成为兄弟单词。提供一个单词,在字典中找到它的兄弟。描述数据结构和查询过程
- 【蛙蛙推荐】创建一个数据字典服务
- NC5.7 IUFO数据字典谁有,请发一个?
- 使用VBS将数据字典中描述转换为中文
- 自定义HID一个输入和输出64字节数据的报告描述符
- 定义一个描述学生(Student)基本情况的类,数据成员包括姓名(name)、学号(num)、数学成绩(mathScore)、英语成绩(englishScore)、人数(count)...
- 利用索引器搞定了一个通用字典数据加载方式。
- 查看标准的FM以及描述等的一个数据…
- oracle数据库之删除数据文件[物理地删除一个数据文件但它的信息仍然记录在数据字典v$datafile中]
- json解析出来的数据库是字典和数组的组合,创建一个model来接收解析数据
- 利用索引器搞定了一个通用字典数据加载方式。
- [生成数据字典]取数据库表中字段的描述信息
- [Oracle][Metadata]如何查找与某一个功能相关的数据字典名
- 一个基于VBA的数据字典生成宏(直接生成word文档)
- 字符移位 小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间。 你能帮帮小Q吗? 输入描述: 输入数据有多组
- 分享一个自己开发的数据字典与动态代码生成工具
- ACM 4描述 输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符。输入 第一行输入一个数N,表示有N组测试数据。后面的N行输入多组数据,每组输入数据都是占一行,
- Python3基础 解析json格式的数据,得到一个字典 json.loads()