- 1、本文档共133页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
面向对象的分析与设计课件-设计篇课件
15.1 面向对象方法与构件技术 4、问题域部分的修改 … … … … 类B … … … … … … … … 类D … … … … 问题域部分 数据接口部分 类A 类C 对象存取器 … … … … 每个持久对象类都要增加请求存储和恢复所需的属性和操作,以便向数据接口部分发出请求 类名 … … 请求保存 请求恢复 … … 类名 … … 请求保存 请求恢复 … … 类名 … … 请求保存 请求恢复 … … 持久对象 请求保存 请求恢复 … … 类名 … … 增加一个一般类来定义它们,作为共同协议,供所有的持久对象类继承 (二)针对RDBMS的设计 应用系统 数据接口 … RDBMS 对象 对象 对象 1、对象及其对数据库的使用 如何看待用 RDBMS存储对象 应用系统仍然是面向对象的 只是用关系数据库存储对象的数据 关系数据库 从应用系统的对象到数据库表元组的不同映射方式 类A 对 象 1 实例化 … 元 组 1 元 组 2 … 元 组 n 对 象 2 对 象 n 内存空间 数据库 表A 一一对应的映射方式 数据接口 RDBMS 类A 数据接口 实例化 元 组 1 元 组 2 … 元 组 n 对 象 内存空间 数据库 表A 非一一对应的映射方式 RDBMS 使用RDBMS和使用文件系统的不同 (1)系统以不同方式使用数据库中的数据 存储对象 或 使用其普通数据 ——原因:数据库的共享性 (2)可能需要数据格式转换 原因:关系数据库对规范化的要求 对象从数据库获得其他数据 关系数据库 ? 应用系统 对象 数据接口 对象 … RDBMS 对象 对象保存与恢复 2、对象在数据库中的存放策略 对象数据的规范化 修改类图 确定关键字 从类图映射到数据库表 类→表 类的属性→表的属性 对象实例→行 对一般-特殊结构、整体-部分结构、关联等OO概念的处理 第一范式(1NF):关系(表)的每个属性都必须是原子的。就是说,关系的每个属性都是单值的,它不再包含内部的数据结构。 第二范式(2NF):如果一个关系的所有非关键字属性都只能依赖整个关键字(而不是依赖关键字的一部分属性),则该关系在第二范式中。 第三范式(3NF):如果一个关系在第二范式中,而且没有传递依赖,则该关系在第三范式中。 Boyce-Codd范式(BCNF):如果一个关系的每个决定因素都是候选关键字,则该关系在BCNF中。 第四范式(4NF):如果一个关系在BCNF中,而且没有多值依赖,则该关系在第四范式中。 1)对象数据的规范化 关系数据库要求存入其中的数据符合一定的规范,并且用范式衡量规范化程度的高低。 是由关系数据模型决定的,是对一个关系的起码要求 主要为了解决关系中的函数依赖带来的更新异常问题。 也可以减少数据冗余,但更新异常问题更为重要 主要为了减少数据冗余 未必规范化程度越高越好 规范化的代价 ——响系统的可理解性,增加了多表查询和连接操作 面向对象方法与关系数据库的规范化目标 既有相违的一面,又有相符的一面 以对象为中心组织数据与操作,恰恰有助于达到第2NF、3NF、BCNF和4NF要求的条件 对象的数据结构常常连1NF的要求都不能满足 例如“通信地址”属性 HOUSING(SID,Building,Fee) Key:SID Functional Dependencies: Building→Fee SID→Building→Fee 100 Randolph 1200 150 Ingersoll 1100 200 Randolph 1200 250 Pitkin 1100 300 Randolph 1200 SID Building Fee 例1:一个不满足3NF的关系及其规范化 STU-HOUSING(SID,Building) Key:SID SID Building 100 Randolph 150 Ingersoll 200 Randolph 250 Pitkin 300 Randolph BLDG-FEE(Building,Fee) Key:Building?? Building Fee Randolph 1200 Ingersoll 1100 Pitkin 1100 从面向对象的观点看应该定义“学生”和“建筑物”两个类 ——恰好与规范化要求吻合 学生 住所 ······ 建筑物 房费 ······ 分析原因:把描述不同事物的数据组织在一起 摘自:施伯乐等 译,[美] David M. Kroenke 著. 数据库处理. 北京:电子工业出版社,
文档评论(0)