本文实例讲述了PHP数据对象映射模式。分享给大家供大家参考,具体如下:
将对象和数据存储映射起来,对一个对象的操作映射为对数据存储的操作。
例如在代码中new
一个对象,使用数组对象映射模式可以将对象的一些操作,比如设置一些属性,就会自动保存到数据库,跟数据库表的一条记录对应起来
在代码中实现数据对象映射模式,我们将实现一个ORM类,将复杂的SQL语句映射成对象属性的操作。同时结合工厂模式和注册模式使用
例1
【例1】
数据库 test ,user 表结构:
1
2
3
4
5
6
7
|
CREATE TABLE ` user ` (
`id` int (11) NOT NULL AUTO_INCREMENT,
` name ` varchar (32) CHARACTER SET utf8 DEFAULT NULL ,
`mobile` varchar (11) CHARACTER SET utf8 DEFAULT NULL ,
`regtime` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP ,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1;
|
Common\User.php:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<?php
namespace Common;
class User{
public $id ;
public $name ;
public $mobile ;
public $regtime ;
protected $db ;
//构造方法
function __construct( $id ) {
$this ->db = new Database\MySQLi();
$conn = $this ->db->connect( '127.0.0.1' , 'root' , '' , 'test' );
$res = $this ->db->query( "select * from user where id = {$id} limit 1" );
$data = $res ->fetch_assoc();
$this ->id = $data [ 'id' ];
$this ->name = $data [ 'name' ];
$this ->mobile = $data [ 'mobile' ];
$this ->regtime = $data [ 'regtime' ];
}
//析构方法
function __destruct() {
$this ->db->query( "update user set name = '{$this->name}', mobile = '{$this->mobile}', regtime = '{$this->regtime}' where id = {$this->id} limit 1" );
}
}
|
Common\Databases\MySQLi.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<?php
namespace Common\Database;
use Common\IDatabase;
class MySQLi implements IDatabase{
protected $conn ;
function connect( $host , $user , $passwd , $dbname ){
$conn = mysqli_connect( $host , $user , $passwd , $dbname );
$this ->conn = $conn ;
}
function query( $sql ){
$res = mysqli_query( $this ->conn, $sql );
return $res ;
}
function close(){
mysqli_close( $this ->conn);
}
}
|
入口文件 index.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<?php
define( 'BASEDIR' ,__DIR__); //定义根目录常量
include BASEDIR. '/Common/Loader.php' ;
spl_autoload_register( '\\Common\\Loader::autoload' );
echo '<meta http-equiv="content-type" content="text/html;charset=utf8">' ;
/*
* 对对象属性的操作就完成了对数据库的操作
*/
$user = new Common\User(1);
//读取数据
var_dump( $user ->id, $user ->mobile, $user ->name, $user ->regtime); exit ();
$user ->mobile = '13800138000' ;
$user ->name = 'Arshavin' ;
$user ->regtime = date ( "Y-m-d H:i:s" ,time());
|
希望本文所述对大家PHP程序设计有所帮助。