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程序设计有所帮助。
您可能感兴趣
- php防session劫持(使用SMB共享来绕过php远程文件包含的限制执行RFI的利用)
- php7处理方案(PHP7 安装event扩展的实现方法)
- phpword生成图片(PHP生成图片的方法分享)
- thinkphp表单提交不到数据(ThinkPHP5.1表单令牌Token失效问题的解决)
- thinkphp标签详解(thinkphp整合系列之极验滑动验证码geetest功能)
- php7用什么替代mysql(mysqli扩展无法在PHP7下升级问题的解决)
- php中数组使用技巧(php常用经典函数集锦数组、字符串、栈、队列、排序等)
- thinkphp继承model如何使用(Thinkphp5.0 框架使用模型Model添加、更新、删除数据操作详解)
- thinkphp5.1插件实现(Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作示例)
- thinkphp支付宝支付(thinkPHP和onethink微信支付插件分享)
- php微信公众号管理后台(php实现微信公众号创建自定义菜单功能的实例代码)
- win7如何搭建php环境(阿里云Win2016安装Apache和PHP环境图文教程)
- php目录使用教程学习(PHP FileSystem 文件系统常用api整理总结)
- php大量数据计算有什么技巧(PHP各种常见经典算法总结排序、查找、翻转等)
- phpstudy修改为什么进不去(phpstudy2018升级后站点及phpmyadmin打开404解决方案)
- php排序代码详解(PHP实现数据四舍五入的方法小结4种方法)
- 宋轶除了演过于曼丽,原来还演过一个青楼女子(宋轶除了演过于曼丽)
- 赵丽颖第一部当女主的戏,主角配角个个都是实力演员(赵丽颖第一部当女主的戏)
- 乾隆为何这么喜爱白塔原因是什么(乾隆为何这么喜爱白塔原因是什么)
- 逐渐消失的东北八大怪现象,进步的社会里我们遗失的是什么(逐渐消失的东北八大怪现象)
- 今日大雪,大雪养生这样做,一年都有好气色(大雪养生这样做)
- 粗盐是什么 粗盐的功效与作用(粗盐的功效与作用)
热门推荐
- dockerfile 添加yum文件(使用YUM 安装 docker的方法步骤)
- dedecms内容上下篇功能(dedecms按键盘方向键实现上一篇下一篇翻页功能)
- navicat premium连接mysql报错(Navicat连接MySQL错误描述分析)
- html5基本标签详解(详解HTML5布局和HTML5标签)
- mysql字符串默认长度(MySQL 字符类型大小写敏感)
- 云服务器租用怎么收费(云服务器租用注意事项有哪些?)
- C#获取页面的HTML
- python异常值处理(一篇文章带你弄懂Python异常传递和自定义异常)
- dedecms安全设置(织梦系统DedeCMS设定栏目及文档权限登录后跳转到登陆前的页面的实现方法)
- 如何在mysql中批量插入数据(MySQL如何快速批量插入1000w条数据)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9