ORM Active Record 和DataMapper的关系

时间:2023-01-12 13:26:36

ORM 是object relationship mapper 俗称对象关系映射。简单点理解就是编程语言里面的对象和关系型数据库的记录产生某种对应关系。


产生背景:

在编程的世界里  一个类的对象通常是这样

<?php
class One{
    private $id;
    protected $name;
    //.....

}

数据库的记录通常是这样

ORM Active Record 和DataMapper的关系


这2种肯定数据结构上面有很大的差别。那么我们就需要有着机制让他们管理起来 是程序开发便捷。这就是ORM的来源。

目前有2种模式实现ORM 分别是 Active Record和 DataMapper


Active Record

他是一种比较简单的实现  主要特征就是 这个类是一个Active Record,它映射为一张数据库的表,它的一个实例指向表的一行。因此这个对象方法的操作 实质上就是对一条记录的操作。使得程序员不需要去关心数据库结构和表而直接操作active record的对象就能操作表。大大加快了编码效率。

一个Active Record 实现类大概是这样

<?php
class One extends ActiveRecord{
    public function insert(){}
    public function delete(){}
    public function select(){}
    public function update(){}
}

我们一般通过子类的形式来使用它。


DataMapper

它就有点高端了。它是一个对象和数据库记录的中间层 旨在使二者隔离,同时和活动记录一样(active record)提供数据的双向传递。它的核心是有一个EntittyManager.通过这个来管理对象和数据库记录的关系。

一个Datamapper可以是这样

<?php
class One {
    public function test(){
        $user = new User();
        $user->id = 90;
        $user->name = 'aaa';
        EntityManage::presist($user);//持久化保存。
    }
}

总结一下:

active record是可以针对项目周期短 ,快速出产品的项目适用的。。datamapper是针对长线项目适用的。

原因就是他们各自对orm实现方式的差别造成的。