概念:简言之,数据映射模式就是将对象和数据存储映射起来,对一个对象的操作会映射为对数据存储的操作。

深入理解:数据映射,是在持久化数据存储层(一般是关系型数据库)和驻于内存的数据表现层之间进行双向数据传输的数据访问层。

数据映射模式的目的是让持久化数据存储层,驻于内存的数据表现层,以及数据映射本身三者相互独立、互不依赖。这个数据访问层由一个映射器(或者数据访问对象)组成,用于实现数据传输。通用的数据访问层可以处理不同的实体类型,而专用的则处理一个或几个。

数据映射模式的核心在于它的数据模型遵循单一职责原则(single Responsibility Principle),这也是和Active Record模式的不同之处。最典型的数据映射模式例子就是数据库ORM模型(Object Relational Mapper)。

代码演示:

1.表结构

+---------+------------------+------+-----+---------+----------------+
| Field   | Type             | Null | Key | Default | Extra          |
+---------+------------------+------+-----+---------+----------------+
| id      | int(11) unsigned | NO   | PRI | NULL    | auto_increment |
| name    | varchar(32)      | NO   |     |         |                |
| mobile  | int(11)          | NO   |     | 0       |                |
| regtime | timestamp        | YES  |     | NULL    |                |
+---------+------------------+------+-----+---------+----------------+

2.代码结构

\Libs\IDatabase.php

<?php
namespace Libs; interface IDatabase
{
function connect($host,$user,$pwd,$dbname);
function query($sql);
function close();
}

\Libs\Database\MySQLi.php

<?php
namespace Libs\Database; use Libs\IDatabase;
class MySQLi implements IDatabase
{
protected $conn; public function connect($host,$user,$pwd,$dbname)
{
$conn = mysqli_connect($host,$user,$pwd,$dbname);
$this->conn = $conn;
}
public function query($sql)
{
$res = mysqli_query($this->conn,$sql);
return $res;
}
public function close()
{
mysqli_close($this->conn);
} }

\Libs\Factory.php

<?php
namespace Libs; class Factory
{
public static function getUser($id)
{
$key = 'user_'.$id;
$user = Register::get($key);
if(!$user){
$user = new User($id);
Register::set($key, $user);
} return $user;
}
}

\Libs\User.php

<?php
namespace Libs; class User
{
public $id;
public $name;
public $mobile;
public $regtime; protected $db;
public function __construct($id)
{
$this->db = new \Libs\Database\MySQLi();
$this->db->connect(DBHOST, DBUSER, DBPWD, DBNAME);
$res = $this->db->query("SELECT * FROM user WHERE id={$id} LIMIT 1"); $data = $res->fetch_assoc();
$this->id= $id;
$this->mobile = $data['mobile'];
$this->name = $data['name'];
$this->regtime = $data['regtime']; }
public function __destruct()
{
$this->db->query("update user set name='{$this->name}',mobile='{$this->mobile}',regtime='{$this->regtime}' where id={$this->id} limit 1"); }
}

\Libs\UserMapper.php

<?php
namespace Libs; class UserMapper
{
public function index($id)
{
$user = \Libs\Factory::getUser($id);
$user->mobile = "1891111111";
$this->changeName($id);
echo "done";
}
public function changeName($id)
{
$user = \Libs\Factory::getUser($id);
$user->name = "sacha";
}
}

调用


define("DBHOST",'127.0.0.1');
define("DBUSER",'user');
define("DBPWD",'pwd');
define("DBNAME",'test'); $um = new \Libs\UserMapper();
$um->index(1);

推荐阅读:

php 设计模式-数据映射模式(应用程序与数据库交互模式)

Eloquent ORM 实例教程 —— ORM概述、模型定义及基本查询

PHP 设计模式系列 —— 数据映射模式(Data Mapper)

PHP数据对象映射模式

php模式-数据映射模式的更多相关文章

  1. Atitit.biz业务系统 面向框架  面向模式---------数据映射imp

    Atitit.biz业务系统 面向框架  面向模式---------数据映射imp 1.1. 面向变量  面向过程  面向对象 面向组件  面向框架  面向服务 面向模式1 1.2. 第2章 架构模式 ...

  2. MFC坐标空间与映射模式

    逻辑坐标:使用GDI绘图时使用的坐标系 设备坐标系:实际设备(显示器.打印机)的坐标系,即我们实际看到的坐标系. 坐标空间 在Windows NT/2000中Win32 API中支持以下四层坐标空间: ...

  3. GDI绘图中的映射模式CDC::SetMapMode()

    原文链接:http://blog.csdn.net/charlessimonyi/article/details/8264572 在GDI绘图前,一般要设置映射模式.映射模式是什么呢?它是逻辑长度单位 ...

  4. Atitit orm的实现模式 data-mapper模式和active-record模式有什么区别

    Atitit orm的实现模式  data-mapper模式和active-record模式有什么区别 1.1. 这是来自Node.js路线有关混合两种ORM模式Active Record(活动记录模 ...

  5. php设计模式 数据对象映射模式

    数据对象映射模式,是将对象和数据存储映射起来,对一个对象的操作会映射为对数据存储的操作. 在代码中实现数据对象映射模式,实现一个ORM类,将复杂的sql语句映射成对象属性的操作.对象关系映射(Obje ...

  6. PHP 设计模式 笔记与总结(10)数据对象映射模式 2

    [例2]数据对象映射模式结合[工厂模式]和[注册模式]的使用. 入口文件 index.php: <?php define('BASEDIR',__DIR__); //定义根目录常量 includ ...

  7. PHP 设计模式 笔记与总结(9)数据对象映射模式

    [数据对象映射模式] 是将对象和数据存储映射起来,对一个对象的操作会映射为对数据存储的操作.例如在代码中 new 一个对象,使用数据对象映射模式就可以将对象的一些操作比如设置一些属性,就会自动保存到数 ...

  8. PHP设计模式笔记六:数据对象映射模式 -- Rango韩老师 http://www.imooc.com/learn/236

    数据对象映射模式 1.数据对象映射模式,是将对象和数据存储映射起来,对一个对象的操作会映射为对数据存储的操作 2.在代码中实现数据对象映射模式,我们将实现一个ORM类,将复杂的SQL语句映射成对象属性 ...

  9. 架构模式数据源模式之:数据映射器(Data Mapper)

    一:数据映射器 关系型数据库用来存储数据和关系,对象则可以处理业务逻辑,所以,要把数据本身和业务逻辑糅杂到一个对象中,我们要么使用 活动记录,要么把两者分开,通过数据映射器把两者关联起来. 数据映射器 ...

随机推荐

  1. Plsql developer 怎么在打开时登陆配置oracel client?

    配置前 logon 这块是空白的,该怎么配置呢? 看下面 --> 安装完plsql 后 需要安装 oracle client, 这里不再赘述,请自行百度.下面将贴出如何使用 oracle cli ...

  2. Python: 列表的两种遍历方法

    方法一:以列表中元素的下标进行访问 def traverse1(list1): for i in range(len(list1)): print(list1[i], end=' ') print() ...

  3. ubuntu 关闭触控板

    第一种: 1 sudo rmmod psmouse    这个是禁用的 2 sudo modprobe psmouse 这个是启用的 这个方法很便捷,但是会将触点和触板都禁用了,一般还是希望保持触点是 ...

  4. Prolog奇怪奇妙的思考方式

    今天在<七周七语言>中接触到了prolog,发现它的编程模式和思考方式的确比较奇怪,但同时也非常奇妙,值得学习一下. 1. prolog语言介绍     和SQL一样,Prolog基于数据 ...

  5. YAGNI 声明

    1.YAGNI介绍 YAGNI 全名是 You aren't Going to Need It,在你设计草案的初稿中,应该努力使用最简单可以工作的事物,直至程序的某个方面要求你添加额外的特性. 2.思 ...

  6. 怎么使用pipenv管理你的python项目

    原文链接:https://robots.thoughtbot.com/how-to-manage-your-python-projects-with-pipenv 翻译者:Jiong 在thought ...

  7. nginx启动和配置

    1.命令行参数 -c </path/to/config> 为 Nginx 指定一个配置文件,来代替缺省的.路径应为绝对路径 -t 不运行,而仅仅测试配置文件.nginx 将检查配置文件的语 ...

  8. preparedstatement execute()操作成功!但是返回false

    转自http://blog.sina.com.cn/s/blog_963fb3af01013rcs.html Connection con = getConn(); String sql2 = &qu ...

  9. js调用本地office打开服务器的office文件预览

    本来是想做成直接在网页上在线预览office文件的,但是找了好多,要不是收费,要不就是要调用别人的API不安全,所以纠结了好久还是用调用本地的office预览office文件. 废话不多说,那么怎么调 ...

  10. POI 导入 一直报400问题

    排查过程:1.400一般都是参数或者请求不对,但是我这个情况是本地好用,只是服务器有问题,所以排除了传值的格式等问题. 2.服务器和本地网络隔离,所以没办法比较代码,分两次全量覆盖了html和js部分 ...