php对象模型(PHP数据对象映射模式实例分析)
类别:编程学习 浏览量:2704
时间:2022-04-01 21:26:04 php对象模型
PHP数据对象映射模式实例分析本文实例讲述了PHP数据对象映射模式。分享给大家供大家参考,具体如下:
将对象和数据存储映射起来,对一个对象的操作映射为对数据存储的操作。
例如在代码中new
一个对象,使用数组对象映射模式可以将对象的一些操作,比如设置一些属性,就会自动保存到数据库,跟数据库表的一条记录对应起来
在代码中实现数据对象映射模式,我们将实现一个ORM类,将复杂的SQL语句映射成对象属性的操作。同时结合工厂模式和注册模式使用
例1
【例1】
数据库 test ,user 表结构:
|
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:
|
<?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
|
<?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
|
<?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程序设计有所帮助。
您可能感兴趣
- phpstudy怎么配置域名并访问(phpstudy怎么绑定目录实现域名访问)
- thinkphp5.0实例详解(ThinkPHP5&5.1框架关联模型分页操作示例)
- linux安装phpstudy(PHPStudy下如何为Apache安装SSL证书的方法步骤)
- php商城支付接口(php实现银联商务公众号+服务窗支付的示例代码)
- php 数据库查询并写入(PHP实现单条sql执行多个数据的insert语句方法)
- php如何建立一个网站(PHP利用DWZ.CN服务生成短网址)
- phpstudy搭建网站全过程(phpstudy在本地搭建多个网站的方法)
- 如何解决php跨域问题(php简单检测404页面的方法示例)
- thinkphp5.1 执行流程(Thinkphp5.0 框架的请求方式与响应方式分析)
- php时间戳是什么意思(php时间戳转换代码详解)
- php错误处理及调试(php报错502 bad gateway解决方法)
- php如何创建二维数组(PHP二维索引数组的遍历实例分析2种方式)
- thinkphp实战教程之博客技术学习(python3编写ThinkPHP命令执行Getshell的方法)
- php设置上传文件代码(PHP大文件切割上传并带进度条功能示例)
- php如何发邮件(PHP示例演示发送邮件给某个邮箱)
- php联合注入列表总结(php中的依赖注入实例详解)
- 换代在即,现在是抄底 7.5代 高尔夫的最佳时机吗(换代在即现在是抄底)
- 2020年大众7.5代高尔夫R终结特别版 最后的呐喊(2020年大众7.5代高尔夫R终结特别版)
- 七年前的这部剧有毒,全剧只有女主红到发紫,男主至今无人认识(七年前的这部剧有毒)
- 宋轶除了演过于曼丽,原来还演过一个青楼女子(宋轶除了演过于曼丽)
- 赵丽颖第一部当女主的戏,主角配角个个都是实力演员(赵丽颖第一部当女主的戏)
- 乾隆为何这么喜爱白塔原因是什么(乾隆为何这么喜爱白塔原因是什么)
热门推荐
- nginx动态路径配置(Nginx本地目录映射实现代码实例)
- php数组详解(php数组和链表的区别总结)
- 接到面试通知后必须做哪些准备
- python 制作图片文字识别(如何使用Python进行OCR识别图片中的文字)
- 如何安装phpmysql环境(phpnow重新安装mysql数据库的方法)
- linux开启ssh服务(Linux ssh服务器配置代码实例)
- pyqt5代码实例(pyqt5实现登录界面的模板)
- python樱花绽放代码(新年快乐! python实现绚烂的烟花绽放效果)
- 云服务器需要都有什么技术(浅谈云服务器配置应该如何选择?)
- mysql中的默认mysql数据库作用(MySQL安装后默认自带数据库的作用详解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9