WEB开发网
开发学院数据库MSSQL Server 甩掉数据字典,让 Sql Server数据库也来一个自描述... 阅读

甩掉数据字典,让 Sql Server数据库也来一个自描述

 2010-04-21 00:00:00 来源:WEB开发网   
核心提示:我们学、用 .NET的都知道,程序集 (Assembly)的一个很大的优点就是它有元数据,甩掉数据字典,让 Sql Server数据库也来一个自描述,可以 “自描述 ”,在我们体验这种优势的同时,就算要一份最新的 Excel格式的数据库字典,也只需要查询出结果,我们是否想过什么时候数据库中的信息

我们学、用 .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里面就行了。

Tags:甩掉 数据 字典

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接