• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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面向对象程序设计入门教程》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

    希望本文所述对大家PHP程序设计有所帮助。

    您可能感兴趣的文章:
    • PHP中数据库单例模式的实现代码分享
    • php设计模式 DAO(数据访问对象模式)
    • 浅析php设计模式之数据对象映射模式
    • PHP基于单例模式实现的数据库操作基类
    • PHP的中使用非缓冲模式查询数据库的方法
    • PHP实现的数据对象映射模式详解
    • PHP单例模式应用示例【多次连接数据库只实例化一次】
    • PHP单例模式数据库连接类与页面静态化实现方法
    • PHP设计模式之数据访问对象模式(DAO)原理与用法实例分析
    • PHP数据源架构模式之表入口模式实例分析
    上一篇:PHP模版引擎原理、定义与用法实例
    下一篇:浅谈php调用python文件
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    PHP数据对象映射模式实例分析 PHP,数据,对象,映射,模式,