鉴定说明书认股鉴定表合同书调查报告市场调查自查报告调查表案例

最新文档

PowerDesigner中的对象与关系映射建模


  文件类型:DOC/Microsoft Word  文件大小:字节

更多搜索:PowerDesigner  中的  对象  关系  映射  建模  
PowerDesigner中的对象与关系映射建模PowerDesigner中的对象与关系映射建模
Sybase 公司PowerDesigner上海研发中心 余亚,王晓昀
概述
从80年代中期开始,随着C++语言的成功,面向对象语言已经成为软件开发中的主导语言.现在很多商用软件,尤其是企业信息系统,都是使用面向对象语言进行开发的.应用面向对象方法,我们通过类来抽象不同类别的实体,属性来表示实体的静态特征,关联来抽象实体间的联系,继承来抽象类别的包含关系.
很多的应用程序都需要进行数据存储,关系型数据库是最常用的数据管理系统.在关系型数据库中,表,列和外键是抽象数据的基本元素.关系型数据库是建立在关系计算和布尔代数基础之上的,SQL是数据库的操作语言,通过关系运算,连接,联合等,来操作数据.
我们很容易的看出,面向对象模型和关系模型是不完全匹配的.比如
对象可以存储到多张表,表也可以存储多个类的对象.
对象之间的关系是双向的,而表之间的关系是单向的.
对象之间有继承关系,表之间没有.
为了解决这种不匹配,人们定义了很多映射模式来建立两种模型间的对应关系.这些映射模式逻辑上解决了模型间的不匹配,使得面向对象程序能够正确地和关系关系型数据库进行交互,但是对于程序的开发,仍然有很多问题需要解决.
问题
对于设计人员来说,他们需要找到并且描述这两种模型元素间的映射关系,以便编程人员能够正确地实现数据的存储和查询.现在很多建模工具仅提供其中一种模型的支持,比如Together仅支持对象建模,ERWin仅支持数据建模.即使同时支持两种模型,这种支持也很不完整,比如Rose中的数据建模功能.分析设计人员常常需要两种不同的工具来进行建模,如果他们想描述这两种模型元素间的对应关系,他们只能通过文档或者表格的形式.这很容易产生错误,并且如果模型发生改变,这些文档需要手工更改,容易造成不一致,维护起来很困难.
对于编码人员,他们需要应用某种技术来实现模型的这种对应关系.如果通过语言提供的数据库访问接口,比如Java的JDBC或者.Net的ADO.Net,对于每一个对象的每一个存储操作,编码人员需要编写存取操作的SQL,数据库控制和访问代码,这是一项繁琐,重复性的劳动.即使应用O/R 映射的框架,比如Hibernate, EJB 3.0或者.Net平台的NHibernate,他们需要编写映射文件或者通过标记来定义O/R映射框架所需要的映射元数据.这些映射元数据只不过是我们在设计阶段定义的映射关系另外一种表现方式,转换成XML或者标记的方式,无疑这种转换增加了错误的可能性和维护的难度.
PowerDesigner解决之道
PowerDesigner提供对于多达8种模型的支持,其中包括面向对象模型和关系数据模型.作为一个集成的企业建模工具,PowerDesigner并不是简单的将几种模型工具罗列在一起.各种模型相互之间可以建立关联,通过这种关联,它提供了企业模型统一,一致的视图.其中模型间的映射和自动生成是建立模型间关联重要的手段.
模型可以描述系统的静态特征和动态特征,而静态特征可以用来表述系统的持久状态,比如面向对象模型中的实体类,数据库模型的表,XML模型中的元素节点等.在PowerDesigner中,我们可以在各种可以描述持久状态模型间建立映射,比如XML模型到面向对象模型间的映射,面向对象模型到关系数据模型的映射等.下面我们就来看一下,PowerDesigner是如何支持面向对象模型到关系模型的映射的.
对象/关系映射
下表列出了PowerDesigner中面向对象元素和关系模型元素间的对应关系:

OOM 元素
PDM 元素




接口

属性

标识符

操作 (具有存储过程范型)
存储过程
操作 (具有存储功能范型)
存储功能
关联
外键或者表
关联类
表和两个指向关联的类所生成表的外键
继承
表或者外键
依赖

实现

引用

表1
在PowerDesigner中,我们可以通过三种方式来建立面向对象模型和关系模型间的映射:
手工建立映射.
自动模型生成.
它们分别适用于不同的开发需求,下面我们就来看如何通过这两种方式来建立映射.
手工建立映射
这种方式适用于以下几种情况:
在已经存在的模型间建立映射.企业的信息系统是一个异构的环境,很多应用程序和数据库都是独立开发的,它们具有不同的模型,如果它们之
·上一篇:刊头题字:李鹤鹏EnterpriseInfoTimes
·下一篇:解决方案
下载链接
相关下载
最热搜索
<%=Components.Fun.GetTemplate(Components.Template.TemplateType.Foot)%>