企业应用架构模式读书笔记(二)
把SQL访问从领域逻辑中分离出来:行数据入口和表数据入口。行数据入口对象对应数据库中表的一行数据。表数据入口对象和记录集差不多,对应表中的多行数据。
把相关领域逻辑移入行数据入口中,行数据入口不但拥有数据,而且拥有行为,这就行成了活动记录。
活动记录适用于领域逻辑复杂度适中的情况,如果领域逻辑复杂度较大,需要按领域模型来组织系统结构,此时,数据对象与数据库中的表不再是一一对应的关系,这时一般采用数据映射器。
视图相当于一张虚表,和真正表之间差别在于只能读取不能修改。
管理内存中的数据对象和数据库中的数据,保持它们的一致性,是一件复杂的事。可以采用工作单元,让工作单元跟踪所有从数据库读取的对象以及所有以任何形式修改过的对象,并由它把数据对象提交到数据库中。
把同一个数据对象加载两次,也即有两个数据对象对应于数据库中同一行数据,这可能产生非常糟糕的后果。可以采用标识映射来保持数据对象的唯一。标识映射一个附带的好处是能提高性能。
如果使用领域模型,对象之间的关系可能比较复杂,产生裙带关系,加载一个对象会附带加载一大堆对象,这时可以采用延迟加载。这和代理模式差不多,先生成一个代理,真正用到该对象时才去加载。
对象之间的关联可以通过外键映射来实现。
一个人有多种技能,并且要知道多少人具备某一项技能,这是一种多对多的关系,关系数据库不能直接解决这类问题,而是通过关联表映射来实现。
通过序列化LOB可以节省大量数据库开销。
继承关系与数据库的映射方法有:
l 单表继承:让所有类都映射到同一个表中,这张表拥有所有父类/子类全部的域。因为数据库会压缩没有用到的域,不会浪费多少空间,而且使用更简单。
l 具体表继承:每个子类对应一张独立的表。
l 类表继承:每个类都对应一张独立的表。
同一个数据对象对应多个数据源时,可以建立多个映射层。
元数据映射:用元数据文件来描述映射关系,通过代码产生或者反射编程来完成映射,这可以大大减少重复的代码。
使用数据连接池,可以避免频繁建立/断开连接的性能开销。
可以把连接的建立/断开与事务关联起来,以避免连接泄露。