元数据(metadata)在企业应用开发中的作用

原创 2005年04月27日 16:50:00

元数据(metadata)在企业应用开发中的作用

元数据(metadata)介绍:
Metadata(元数据),它是关于数据的数据”(data about data),近年来在软件设计中Metadata有广泛的应用。
在编程中,元数据不是被处理的对象,而是通过改变元数据的一些来改变程序的运行的数据。
可以解释程序的运行时,不同的元数据值可以让同一段程序有不同的运行结果。
元数据(metadata)应用:

在以前的工作中,经常遇到这样的问题,

SqlServer数据库中一个表如下:

CREATE TABLE [dbo].[DProfile] (

       [Profile_ID] [int] IDENTITY (1, 1) NOT NULL ,

       [ProfileName] [varchar] (250) COLLATE Chinese_PRC_CI_AS NULL ,

       [OtherInfo] [varchar] (500) COLLATE Chinese_PRC_CI_AS NULL ,

       [ValidateStatus] [int] NULL

) ON [PRIMARY]

为其定义一个实体类:

namespace E_Commerce.Data

{

       /// <summary>

       /// 卡属性基本信息实体

       /// </summary>

       public class DProfileInfo

       {

              /// <summary>

              /// 其他信息

              /// </summary>

              public string OtherInfo

              {

                     get

                     {

                            /*Begin Template                       

return mOtherInfo;                 

                            /*End Template Expansion{9D774738-E901-427A-86E7-EF2715768C17}*/

                     }

                     set

                     {

                            /*Begin Template Expansion{F6A2B75D-D01B-47B0-B65D-E62E43286DDC}*/

                            mOtherInfo = value;                    

                            /*End Template Expansion{F6A2B75D-D01B-47B0-B65D-E62E43286DDC}*/

                     }

              }

              /// <summary>

              /// 卡属性ID

              /// </summary>

              public int Profile_ID

              {

                     get

                     {

                            /*Begin Template Expansion{2230D3C4-9766-4778-9203-5063D88B468C}*/

                            return mProfile_ID;              

                            /*End Template Expansion{2230D3C4-9766-4778-9203-5063D88B468C}*/

                     }

                     set

                     {

                            /*Begin Template Expansion{0A1C9514-4DDB-4079-BE19-8DACE24CD454}*/

                            mProfile_ID = value;                   

                            /*End Template Expansion{0A1C9514-4DDB-4079-BE19-8DACE24CD454}*/

                     }

              }

              /// <summary>

              /// 卡属性名称

              /// </summary>

              public string ProfileName

              {

                     get

                     {

                            /*Begin Template Expansion{A43788B8-60A0-4882-9C51-A3DEE710FE78}*/

                            return mProfileName;                  

                            /*End Template Expansion{A43788B8-60A0-4882-9C51-A3DEE710FE78}*/

                     }

                     set

                     {

                            /*Begin Template Expansion{829EEF0A-A18A-4492-BE57-67C4C57ACFC3}*/

                            mProfileName = value;                

                            /*End Template Expansion{829EEF0A-A18A-4492-BE57-67C4C57ACFC3}*/

                     }

              }

              private string mOtherInfo;

              private int mProfile_ID;

              private string mProfileName;

       }

}
在开发和实际运行过程中经常发生这样情况,经过一段时间用户的实际情况变化了,可能想要在上面的实体中和其所对应的数据库的Table中增加一个或多个Field。我们只能修改这个数据实体,在代码开发完成后,进行这样的修改是麻烦而且可能相当危险的。

设想一下现在的情况,由于种种原因需要更改上面的数据结构,我们打算增加两个字段“Price”“CreateTime”,有什么方法可以让数据实体容易适应的进行这种变化呢

两种方法:

1)  在表DProfile中增加一个描述所增加的Field的元数据字段名称为FieldsMetaInfo,数据类型可以定义成Text类型或image等二进制类型,在这个字段中定义一个XML格式的文档描述和存储所新增加的Field

格式可能是这样的

<Field Name="Price" FromBaseType="TRUE" Type="Text" DisplayName="价格" Required="TRUE" MaxLength="255" DefaultValue=”0”  >123.45</Field>

<Field Name=" CreateTime " FromBaseType="TRUE" Type="DateTiem" DisplayName="价格" Required="TRUE"  >2004-01-01</Field>

这个新添加的字段记录未来可能增加的field的数据类型信息和数据信息等其它信息

2)  增加两个表

在表中存储新增加的Field信息

ProfileFields

ID  int

FieldName nvarchar(50)

FieldType  nvarchar(50)

ProfileFieldsValue

ID int

ProfileID int

ProfileValue varchar(50)

ProfileFields表存储增加的Field名称类型等信息

ProfileFieldsValue表存储对应Filed的值

 

在数据实体类中增加一个自定义类型的属性返回存储在源数据结构中的数据

可以是Hashtable类型,也可以是自定义的其它集合类型

Private Hashtable metaFieldsList;

自定义结构用来方便的存储和更新

 


元数据(metadata)数据存储结构:
元数据有许多存储格式,其中最多使用的是xml格式。
xml
最适合用来存储元数据,易与使用和解析。

元数据(metadata)o-r映射中所起的作用:

 

元数据在实际项目的应用

最早接触元数据概念是在学习数据仓库相关知识时,其描述数据仓库内数据的结构和建立方法的数据。其实元数据在OLTP系统中也非常重要,利用元数据可以让系统功能更灵活、更强大。本文结合示例详细阐述元数据在项目...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

java数据库编程——元数据(metadata)+web 与企业应用中的连接管理

【0】README1) 本文部分文字描述转自 core java volume 2 , 测试源代码均为原创, 旨在理解 java数据库编程——元数据(metadata)+web 与企业应用中的连接管理...

企业应用架构模式之对象-关系元数据映射模式

对象-关系元数据映射模式是用来描述数据库中域是如何对应到内存对象中的域的,它包括元数据映射、查询对象、资源库三种模式。 元数据映射:在元数据中保持对象-关系映射的详细信息 该模式最主要的决策是...

OSGI企业应用开发(四)使用Blueprint整合Spring框架(一)

上篇文章中介绍了如何使用独立的Equinox发行包搭建OSGI运行环境,而不是依赖与具体的Eclipse基础开发工具,本文开始介绍如何使用Blueprint將Spring框架整合到OSGI中。一、开发...

OSGI企业应用开发(一)OSGI简介

一、OSGI简介OSGI全称为Open Service Gateway Initiative(开放服务网关规范),有两个层面的含义,一方面它指OSGi Alliance组织;另一方面指该组织制定的一个...

OSGI企业应用开发(十)整合Spring和Mybatis框架(三)

上篇文章中,我们已经完成了OSGI应用中Spring和Mybatis框架的整合,本文就来介绍一下,如何在其他Bundle中,使用Mybatis框架来操作数据库。为了方便演示,我们新建一个新的Plug-...

Flex企业应用开发实践学习笔记(五)-------组件失效机制

组件失效机制(invalidation mechanism)是Flex用来提高应用性能的一项技术,组件生命周期与布局主要利用这一机制来实现,本节对该机制进行总结并探讨该机制如何实现。      ...

OSGI企业应用开发(八)整合Spring和Mybatis框架(一)

到目前为止,我们已经学习了如何使用Blueprint將Spring框架整合到OSGI应用中,并学习了Blueprint&Gemini Blueprint的一些使用细节。本篇文章开始,我们將Mybati...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:元数据(metadata)在企业应用开发中的作用
举报原因:
原因补充:

(最多只允许输入30个字)