php. mysql映射_php模式-数据映射模式

本文介绍了数据映射模式的概念及其实现方式,该模式通过在内存数据层与持久化存储层间建立映射,实现两者之间的解耦。文章还通过一个PHP ORM实例详细展示了数据映射模式的工作原理。

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

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

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

数据映射模式的核心在于它的数据模型遵循单一职责原则(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

namespace Libs;interfaceIDatabase

{function connect($host,$user,$pwd,$dbname);function query($sql);functionclose();

}

\Libs\Database\MySQLi.php

namespace Libs\Database;useLibs\IDatabase;class MySQLi implementsIDatabase

{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 functionclose()

{mysqli_close($this->conn);

}

}

\Libs\Factory.php

namespace Libs;classFactory

{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

namespace Libs;classUser

{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

namespace Libs;classUserMapper

{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);

推荐阅读:

version: "3.8" networks: zabbix-net: driver: bridge ipam: config: - subnet: 172.20.0.0/24 services: mysql-server: image: mysql:8.0.36 container_name: mysql-server restart: unless-stopped environment: MYSQL_DATABASE: zabbix MYSQL_USER: zabbix MYSQL_PASSWORD: Zmsl@123 MYSQL_ROOT_PASSWORD: Zmsl@123 TZ: Asia/Shanghai command: > --default-authentication-plugin=mysql_native_password --character-set-server=utf8 --collation-server=utf8_bin volumes: - mysql_data:/var/lib/mysql - mysql_logs:/var/log/mysql - mysql_conf:/etc/mysql/conf.d ports: - "3306:3306" networks: zabbix-net: ipv4_address: 172.20.0.10 zabbix-java-gateway: image: zabbix/zabbix-java-gateway:alpine-6.2-latest container_name: zabbix-java-gateway restart: unless-stopped environment: TZ: Asia/Shanghai networks: zabbix-net: ipv4_address: 172.20.0.20 zabbix-server-mysql: image: zabbix/zabbix-server-mysql:6.2-alpine-latest container_name: zabbix-server-mysql restart: unless-stopped depends_on: - mysql-server - zabbix-java-gateway environment: DB_SERVER_HOST: mysql-server MYSQL_DATABASE: zabbix MYSQL_USER: zabbix MYSQL_PASSWORD: Zmsl@123 MYSQL_ROOT_PASSWORD: Zmsl@123 ZBX_JAVAGATEWAY: zabbix-java-gateway ZBX_JAVAGATEWAY_TIMEOUT: 30 ZBX_START_POLLERS: 5 ZBX_START_POLLERS_UNREACHABLE: 1 TZ: Asia/Shanghai volumes: - /data/zabbix/alertscripts:/usr/lib/zabbix/alertscripts:ro - zabbix_server:/etc/zabbix - /data/zabbix/server:/var/lib/zabbix - /data/zabbix/log:/var/log/zabbix ports: - "10051:10051" networks: zabbix-net: ipv4_address: 172.20.0.30 zabbix-web-nginx-mysql: image: zabbix/zabbix-web-nginx-mysql:alpine-6.2-latest container_name: zabbix-web-nginx-mysql restart: unless-stopped depends_on: - mysql-server - zabbix-server-mysql environment: PHP_TZ: Asia/Shanghai ZBX_SERVER_HOST: zabbix-server-mysql DB_SERVER_HOST: mysql-server MYSQL_DATABASE: zabbix MYSQL_USER: zabbix MYSQL_PASSWORD: Zmsl@123 MYSQL_ROOT_PASSWORD: Zmsl@123 ports: - "7099:8080" networks: zabbix-net: ipv4_address: 172.20.0.40 zabbix-agent: image: zabbix/zabbix-agent:alpine-6.2-latest container_name: zabbix-agent restart: unless-stopped environment: ZBX_HOSTNAME: zabbix-server-docker ZBX_SERVER_HOST: zabbix-server-mysql ZBX_SERVER_PORT: 10051 ZBX_PASSIVE_ALLOW: "true" ZBX_ACTIVE_ALLOW: "true" volumes: - zabbix_agent:/etc/zabbix ports: - "10050:10050" networks: zabbix-net: ipv4_address: 172.20.0.50 cap_add: - NET_RAW - NET_ADMIN volumes: mysql_data: mysql_logs: mysql_conf: zabbix_server: zabbix_agent:
最新发布
08-20
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值