ORM Active Record 和DataMapper的关系

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

产生背景:

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

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

}
数据库的记录通常是这样

这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实现方式的差别造成的。


---------------------

 https://blog.csdn.net/dzyweer/article/details/79920620?utm_source=blogxgwz7

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值