第二部分:对象之间的关联

关联类型: 一对一、一对多 、多对多

一对多关联可以用一个集合类型的实例变量来实现,也可以使用一个访问方法来查询数据库,找到相关记录,并用这些记录来实例化对象。这两种设计方法反应了同一个模型。设计时必须指定一种遍历机制,这种遍历行为应该和模型中的关联一致。

现实中有大量的"多对多"关联,很多关联天生就是双向的,但这些普遍存在的关联会使实现和维护变动很复杂。

在这里有几种方法可以使得关联易于控制

1.规定一个遍历方向
2.添加一个限定符,以便更有效地减少多重关联
3.消除不必要的关联

关联进行约束是非常重要的,双向关联意味着只有将这两个对象放在一起考虑才能理解他们。当应用程序不要求双向遍历时,可以指定一个遍历方向,以便减少相互依赖,并简化设计。

限定多对多的关联遍历方向可以有效的将其实现简化为一对多的关联,使用限定符可以有效的将一对多关联,简化成一对一关联。从而得到一个简单得多的设计。

坚持将关联限定为领域所倾向的方向,不仅可以提高这些关联的表达力并简化其实现,而且还可以突出剩下的双向关联的重要性。当双向关联是领域的一个语义特征时,或者当应用程序功能需求双向关联时,需要保留它,以便表达出这些需求。

相关推荐
自由鬼11 天前
企业架构与IT架构关系的探讨
程序人生·安全·架构·安全架构·企业架构·it架构
ProcessOn官方账号12 天前
数据分析对比图表-雷达图全面指南
大数据·人工智能·程序人生·职场和发展·数据分析·学习方法·processon
南国_之恋13 天前
程序人生,人生如戏
程序人生·职场和发展
劳埃德福杰13 天前
【系统规划与管理师第二版】1.3 新一代信息技术及发展
系统架构·软件工程·设计规范
TGC达成共识13 天前
解锁身心密码:从“心”拥抱健康生活
科技·物联网·程序人生·百度·生活·新浪微博·高考
nbsaas-boot14 天前
Vue 项目中的组件职责划分评审与组件设计规范制定
前端·vue.js·设计规范
宇钶宇夕14 天前
博图SCL中CONTINUE语句详解:高效循环控制案例
运维·程序人生·算法·自动化
zhangxiaolong01016 天前
我关于汽车的一些看法
程序人生
测试界萧萧17 天前
10:00开始面试,10:06就出来了,问的问题有点变态。。。
自动化测试·软件测试·功能测试·程序人生·面试·职场和发展