随笔分类 -  企业引用架构模式

Martin Fowler著
摘要:Transaction Script使用过程来组织业务逻辑,每个过程处理来自表现层的单个请求.运行机制尽可能将其放置于与表现层和数据源层隔离的类中.为了便于修改和测试,不能调用任何表现层逻辑.组织成类一个类,围绕一个主题将相关事务脚本组织在一起.Command模式.一个事务脚本对应一个类.优点:允许... 阅读全文

posted @ 2014-05-15 09:34 RobynHYB 阅读(916) 评论(0) 推荐(0)

摘要:Table Data Gateway充当数据库表访问入口的对象.一个实例处理一个表中所有的行.在应用逻辑中混杂SQL语句会引起问题.表数据入口包含了用于访问单个表或者视图的所有SQL.其他代码调用它的方法来实现所有与数据库的交互.运行机制其用于数据读写,因此是无状态的.每个方法都将输入参数映射为SQ... 阅读全文

posted @ 2014-05-15 09:33 RobynHYB 阅读(399) 评论(0) 推荐(0)

摘要:维护受业务事务影响的对象列表,并协调变化的写入和并发问题的解决.从DB中存取Data时,必须记录增删改动作,以将对DB有影响的数据写会到DB中去.如果在每次修改对象模型时就对DB进行相应的修改,会造成大量小规模的DB调用,降低了速度.工作单元记录业务事务中对DB有影响的所有变化.然后在操作结束后,了... 阅读全文

posted @ 2014-05-15 09:32 RobynHYB 阅读(293) 评论(0) 推荐(0)

摘要:通过在Map中保存每个已加载过的对象,确保每个对象只加载一次.当要访问对象时,首先检查标识映射,看需要的对象是否已经存在其中.使用Identify来确保不重复加载相同的数据,不仅有助于保证正确性(不会将同一数据加载到两个不同的对象上),还能提升性能.运行机制基本思想:使用一系列映射.这些映射包含了从... 阅读全文

posted @ 2014-05-15 09:31 RobynHYB 阅读(485) 评论(0) 推荐(0)

摘要:一个对象,它虽然不包含所需要的所有数据,但是它知道怎么获取这些数据设计专门的对象来把数据从DB中加载到内存中.该对象可以完成在加载所需对象的同时,把与之相关的对象也一并加载了.否则,必须显示加载所有所需的对象.但是,加载一个对象可能会引起大量相关对象的加载.当真正需要的对象只有几个时,会损害系统的性... 阅读全文

posted @ 2014-05-15 09:30 RobynHYB 阅读(289) 评论(0) 推荐(0)

摘要:在对象中保存DB的ID字段,以维持内存对象和DB数据Row之间的identify.关系DB使用key来区分数据行.而内存对象不需要这样的键.因为对象系统能够保证身份确认.读取时没有问题,但是为了正确地写回DB.需要联系两者.本质上,只是将DB表的主键存储在对象的field上.工作机制键的选择mean... 阅读全文

posted @ 2014-05-15 09:29 RobynHYB 阅读(237) 评论(0) 推荐(0)

摘要:把对象间的关系映射到DB表键的外键引用对象之间可以通过对象引用来互相直接访问.运行机制关键是标识域.一对一的关联.使用一个DB的外键取代.一对多的对象集合.不能在DB中把相连的对象集合都保存了.必须颠倒引用的方向一张唱片有多个曲目,那么在曲目表中保存唱片的外键.更新时较为麻烦插入和删除在多的一方(曲... 阅读全文

posted @ 2014-05-15 09:28 RobynHYB 阅读(272) 评论(0) 推荐(0)

摘要:把关联保存为一个表,存储关联表的外键在对象中,使用集合作为域值,来处理多值域.而在DB中,只能有单值域.外键映射的核心,是在关联关系的单值端使用外键来维持联系.而在多对多的关联关系中,已经不存在单值端了.运行机制使用一个链接表来保存关联关系.仅有两个字段,即两个关联表的外键ID.对于每一对相关联的对... 阅读全文

posted @ 2014-05-15 09:27 RobynHYB 阅读(495) 评论(0) 推荐(0)

摘要:让一个类为其子类(泛意上的)执行DB映射一些对象肯定会出现在另一对象的上下文中.此时,使用另一对象的Mapper来执行第一个对象的映射,来简化映射过程.运行机制在DB持久化时,依赖者类依赖于所有者类.每个依赖者只能有一个所有者.活动记录和行数据入口依赖者类的映射代码都写在所有者中.数据映射器没有依赖... 阅读全文

posted @ 2014-05-15 09:26 RobynHYB 阅读(265) 评论(0) 推荐(0)

摘要:Embedded Value把一个对象映射成另一个对象表中的若干字段.OO系统中会有很多小对象(DataRange,Money).而作为表在DB中毫无意义.默认想法是把一个对象保存为一个表.但是,将这些小对象,映射为该对象所有者记录中的若干字段.运行机制可以看做一种特殊的依赖映射.该值对象是一个依赖... 阅读全文

posted @ 2014-05-15 09:25 RobynHYB 阅读(266) 评论(0) 推荐(0)

摘要:使用将若干相似的类映射为单表,对拥有许多特殊数据的类使用具体表继承.对高层次使用类表继承,对低层次使用具体表继承.Single Table Inheritance在DB中将类继承层次设计为一个单表,表中各列代表不同类中的所有域.运行机制每个类负责把与之相关的数据保存在表的一行中.表中其它不相关的列留... 阅读全文

posted @ 2014-05-15 09:24 RobynHYB 阅读(479) 评论(0) 推荐(0)

摘要:MetaData Mapping元数据映射在MetaData中保存object-relation映射的详细信息.以表格形式定义映射,并可由通用代码来处理映射.运行机制MetaData中的信息如何以运行时Code的形式表现.Code Generation程序:输入是MetaData,输出是映射实现类的... 阅读全文

posted @ 2014-05-15 09:23 RobynHYB 阅读(607) 评论(0) 推荐(0)

摘要:Remote Facade远程外观在OO模型中,存在很多规模小,且有小方法的对象.这些小对象会导致很多的对象间交互.在单一地址空间里,小对象没问题.但是,当在两个进程间做调用时,频繁的跨进程交互会造成性能开销.远程外观,减少远程调用的次数.建立在大量的细粒度对象之上,提供一个粗粒度的外观.不包括任何... 阅读全文

posted @ 2014-05-15 09:22 RobynHYB 阅读(243) 评论(0) 推荐(0)

摘要:每次只允许一个业务事务来访问数据,以防止并发业务事务中的冲突.离线并发处理通常会出现多个业务事务操作同一数据.最简单的办法是为整个业务事务保持一个系统事务.但是事务系统不适合于处理长事务.首选乐观离线锁.而悲观离线锁,作为它的补充.从一开始就避免冲突.它要求业务事务在对数据进行操作前就必须获取该数据... 阅读全文

posted @ 2014-05-15 09:21 RobynHYB 阅读(238) 评论(0) 推荐(0)

摘要:用一个锁Lock一组相关的对象有时,需要按组来修改多个对象.这样,在需要锁住其中一个的时候,必须连带地将其他的对象都上锁.为每一个对象都加上一个锁是很繁琐的.粗粒度锁是覆盖多个对象的单个锁.简化了加锁行为.且不必为了给它们加锁而加载所有对象.运行机制为一组对象建立一个控制点.使用乐观离线锁让组中每个... 阅读全文

posted @ 2014-05-15 09:18 RobynHYB 阅读(345) 评论(0) 推荐(0)

摘要:Client Session State 客户会话状态.在Client端保存会话状态.运行机制Client在每次请求时会把所有的会话数据传给Server,Server在响应时把所有的会话状态传给Client.可以是完全无状态的Server.通常使用可序列化的DTO对象来传递数据.在HTML中,可选的... 阅读全文

posted @ 2014-05-15 09:17 RobynHYB 阅读(211) 评论(0) 推荐(0)

摘要:在两个独立的对象之间建立通信的对象需要在两个必须相互隔离的子系统间建立通信.可能是因为无法修改已有的子系统,或者不愿意在两者之间建立依赖关系.甚至不愿意这两个子系统与另一个部件间建立依赖关系.运行机制控制着子系统键的通信细节.但是并不被子系统感知.难点是如何激活映射器进行(在子系统间的)数据交换.因... 阅读全文

posted @ 2014-05-15 09:16 RobynHYB 阅读(290) 评论(0) 推荐(0)

摘要:Layer Supertype层超类型某一类型充当一层中所有类型的超类型.(DomainObject).运行机制当软件某一层中所有对象有公共特征时,可以将这些特征提取到一个超类上去.Separated Interface分离接口在一个包中定义接口,而在另一个与之分离的保重实现该接口.为了减少系统部件... 阅读全文

posted @ 2014-05-15 09:15 RobynHYB 阅读(256) 评论(0) 推荐(0)

摘要:架构架构的定义最高层次的系统分解.系统中不易改变的决定.主观上的,对系统的组成部分和各部分件交互关系的设计的可共享的理解.层次如何分层,以及层间如何协作.企业应用虽然部分模式适合于所有软件,但是大多数模式仅适合于某些特定领域和分支.特征持久化数据.程序多次运行都需要这些数据.数据的生命周期可能比软件... 阅读全文

posted @ 2014-05-15 09:14 RobynHYB 阅读(183) 评论(0) 推荐(0)

导航