架构模式中的Active Record和Data Mapper

Posted 腾飞

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了架构模式中的Active Record和Data Mapper相关的知识,希望对你有一定的参考价值。

架构模式中的Active Record和Data Mapper

概念
  • 在简单应用中,领域模型是一种和数据库结构一致的简单结构,对应每个数据库表都有一个领域类,在这种情况下,有必要让每个对象负责数据库的存取过程,这也就是Active Record(活动记录)。
  • 领域对象直接鱼数据库表进行交互,这带来了一个问题,随着领域逻辑变的更加复杂,它就慢慢转变成一个大的领域模型,简单的Active Record已经不能满足要求了。
  • 领域类和表一对一匹配也开始随着把领域逻辑放入更小的类而失效。关系数据库无法处理继承,因此使用策略模式等面相对象模式非常困难。
  • 一种更好的办法是把数据库和数据库完全独立,让间接层完全领域对象和数据库表之间的映射,这个映射类也称作Data Mapper(数据映射器)。这个映射类处理数据库和领域模型之间所有的存取操作,并且允许双方都能独立变化。
  • 如果领域逻辑非常简单并且类和表十分一致,使用简单的Active Record就足够了。如果领域逻辑比较复杂,长线项目,Data Mapper则可能是需要的。
ORM中的Active Record和Data Mapper
  • Ruby和Laravel的ORM都采取了Active Record的模式,因此它们ORM可能像下面这样:
 $user = new User;
$user->username = ‘philipbrown‘;
$user->save();
  • 再来看使用Data Mapper的ORM是怎样的:
$user = new User;
$user->username = ‘philipbrown‘;
EntityManager::persist($user);
  • 现在我们察看到了它们最基本的区别:在Active Record中,领域对象有一个save()方法,领域对象通常会继承一个ActiveRecord的基类来实现。而在Data Mapper模式中,领域对象不存在save()方法,持久化操作由一个中间类来实现。

以上是关于架构模式中的Active Record和Data Mapper的主要内容,如果未能解决你的问题,请参考以下文章

业务逻辑层-Active Record

Data Mapper 是否比 Active Record 更现代的趋势?

Active Record 和表数据网关的区别

CodeIgniter Active Record - 获取返回的行数并获取总和

Rails Active Record连接查询与排序和限制

CodeIgniter:如果 Active Record 找不到任何数据,则返回 FALSE