CREATE VIEW [dbo].[DOC_vwColumns]
AS
-- 数据表字段的说明
-- 作者:RickyLin, http://Ricky81317.iyunv.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条件,从这个视图中筛选出你需要的个别表的字段信息
CREATE VIEW [dbo].[DOC_vwObjects]
AS
-- 数据库对象的说明
-- 作者:RickyLin, http://Ricky81317.iyunv.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里面就行了。