- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
将对象映射到关系数据库:对象/
关系映射(O/R Mapping)详解
满江红翻译团队声明:本文是在获得Scott W. Ambler的授权后进行翻译的,原文在
/essays/mappingObjects.html#MappingInheritance
,本文版权属于Ambler,我们放弃除署名权之外的翻译权利,可以在网上随意转载发表,不
得用于商业目的,不得修改pdf文件。
本文是从Agile Database Techniques的第 14 章中截取的。
大多数现代商业应用开发项目使用面向对象技术,比如采用Java或者C#来创建应
用软件,同时使用关系型数据库来存储数据。但这并不是要说你没有其它选择,
也有许多应用程序是使用面向过程的语言开发,比如COBOL,而且也有许多系统
使用对象型数据库或者XML数据库来存储数据。然而,因为面向对象和关系数据
库技术到目前为止已经成为一种事实上的标准,在本章节中我假设你正在使用这
些技术。如果你采用其它的存储技术,本文里的许多概念仍然适用,只需要做一
点点修改(不必担心,Realistic XML总括了对象与XML映射的相关问题)。
在项目组通常用来创建以软件为基础的系统时,那些技术中,存在着面向对象技
术和关系型技术之间的阻抗失配。不过这种阻抗失配很容易被克服,秘诀在于两
点:你需要理解把对象映射到关系型数据库的过程,以及如何去实现这些映射。
在本章节里,“映射”一词是用来表示如何把对象和对象之间的关系对应到数据
库表以及表之间的关系。你将很快发现这并不像听起来的那样简单易懂,尽管它
实际上也不是那么的槽糕。
目录
• 敏捷DBA 的角色
• 基本概念
o Shadow信息
o 映射元数据
o 如何使映射适合全过程
• 继承结构的映射
o 整个层次结构映射到一张表
o 每个具体类映射到单独的一张表
o 每个类单独映射到一张表
o 将类映射为一个通用的表结构
o 多重继承映射
________________________________________
满江红翻译团队: - 1 -
o 映射策略之间的比较
• 映射对象关系
o 关系的类型
o 如何实现对象关系
o 如何实现关系数据库中的关系
o 关系映射
一对一映射
一对多映射
多对多映射
o 映射有序集合
o 映射递归关系
• 映射类作用域(Class-Scope )属性
• 性能调优
o 优化你的映射
o 延迟读取
• 为什么数据Schema不应该主导对象Schema
• 实现方式对对象的影响
• 模型驱动体系结构(MDA: Model Driven Architecture) 的含义
• 映射技术模式化
• 参考文献和阅读推荐
1. 敏捷DBA 的角色
图 1 显示了一个敏捷 DBA 在映射对象到关系数据库的过程中所扮演的角色。其中我们关心
三个主要的活动。
1. 映射。基本的目标是决定一个有效的策略来持久化对象数据。这包括保存单个对象
的属性以及对象之间的关联,同时也包括那些类之间的继承结构。
2. 实现映射
3. 性能调优
在图 1 中我们注意到有一个有趣的事情,敏捷的 DBA 和应用程序开发人员在在这
三个主要活动中都在一起工作。虽然敏捷的 DBA 应该确保映射的有效性,但他们
实际上并不是独自对其负责的。与他人协同工作而不单打独斗正是敏捷软件开发
成功的关键所在。
图 1. 映射时敏捷DBA 的角色。
________________________________________
满江红翻译团队: - 2 -
文档评论(0)