## 8-1 数据对象映射模式之简单案例实现
### 1. 创建`user`表
~~~
-- 创建用户表
CREATE TABLE IF NOT EXISTS `user`(
`id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
`name` VARCHAR(30) NOT NULL DEFAULT '',
`passwd` VARCHAR(32) NOT NULL DEFAULT 'e10adc3949ba59abbe56e057f20f883e',
`created_time` INT(10) NOT NULL DEFAULT 0
)ENGINE=InnoDB DEFAULT CHARSET=UTF8;
-- 测试数据
INSERT INTO `user` (name, passwd, created_time) VALUES
('Mark', md5('12345'), UNIX_TIMESTAMP()),
('Lily', md5('12345'), UNIX_TIMESTAMP()),
('Lucy', md5('12345'), UNIX_TIMESTAMP()),
('Bob', md5('12345'), UNIX_TIMESTAMP()),
('Tom', md5('12345'), UNIX_TIMESTAMP()),
('Christian', md5('12345'), UNIX_TIMESTAMP());
~~~
### 2. 创建`User`类
*D:\wamp\www\demo\oop\framework\Think\User.php*
~~~
<?php
namespace Think;
class User
{
public $id;
public $name;
public $passwd;
public $created_time;
function __construct($id)
{
// 创建对象后,自动执行
}
function __destruct()
{
// 对象注销前,自动执行
}
}
~~~
### 3. 使用构造方法实现数据的读取操作
*D:\wamp\www\demo\oop\framework\Think\User.php*
~~~
<?php
namespace Think;
class User
{
public $id;
public $name;
public $passwd;
public $created_time;
protected $db;
function __construct($id)
{
// 创建对象后,自动执行
$this->db = new Database\MySQLi();
$this->db->connect('localhost', 'root', 'root', 'demo');
$ret = $this->db->query('SELECT * FROM `user` WHERE `id` = ' . $id);
$this->db->close();
$data = mysqli_fetch_assoc($ret);
$this->id = $data['id'];
$this->name = $data['name'];
$this->passwd = $data['passwd'];
$this->created_time = $data['created_time'];
}
function __destruct()
{
// 对象注销前,自动执行
}
}
~~~
### 4. 在入口文件处,获取数据表中的值
*D:\wamp\www\demo\oop\framework\index.php*
~~~
// 实例化1个用户表对象:User
$user = new Think\User(2);
// 获取对象中的属性,对象数据表中的一条记录
echo $user->id."<br/>";
echo $user->name."<br/>";
echo $user->passwd."<br/>";
echo $user->created_time."<br/>";
~~~
### 5. 使用析构方法自动保存数据
*D:\wamp\www\demo\oop\framework\index.php*
~~~
// 修改属性值之后,利用析构方法自动保存
$user->name = '王五';
$user->passwd = md5('123');
$user->created_time = time();
~~~
*D:\wamp\www\demo\oop\framework\Think\User.php*
~~~
function __destruct()
{
// 对象注销前,自动执行
$sql = "UPDATE `user` SET name = '{$this->name}', passwd = '{$this->passwd}', created_time = '{$this->created_time}' WHERE id = {$this->id}";
echo $sql;
$this->db->query($sql);
$this->db->close();
}
~~~
- 序言
- 第1章 课程简介
- 1-1 大话PHP设计模式课程简介
- 第2章 开发环境准备
- 2-1 关于PHPStorm使用
- 2-2 关于编程字体选择
- 2-3 关于运行环境搭建
- 第3章 命名空间与Autoload
- 3-1 关于命名空间
- 3-2 类自动载入
- 3-3 开发一个PSR-0的基础框架
- 第4章 PHP面向对象
- 4-1 SPL标准库简介
- 4-2 PHP链式操作的实现
- 4-3 PHP魔术方法的使用
- 第5章 三种基础设计模式
- 5-1 工厂模式
- 5-2 单例模式
- 5-3 注册树模式
- 第6章 适配器模式
- 6-1 适配器模式
- 第7章 策略模式
- 7-1 策略模式的实现和使用
- 7-2 策略模式的控制反转
- 第8章 数据对象映射模式
- 8-1 数据对象映射模式之简单案例实现
- 8-2 数据对象映射模式之复杂案例实现
- 第9章 观察者模式
- 第10章 原型模式
- 第11章 装饰器模式
- 第12章 迭代器模式
- 第13章 代理模式
- 第14章 综合实战
- 14-1 面向对象设计基本原则
- 14-2 MVC结构
- 14-3 自动加载配置
- 14-4 从配置中生成数据库连接
- 14-5 装饰器模式在MVC中的使用
- 14-6 观察者模式在MVC程序中的使用
- 14-7 代理模式在MVC程序中的使用
- 14-8 课程小结