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

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PHP数据源架构模式之表入口模式实例分析

    本文实例讲述了PHP数据源架构模式之表入口模式。分享给大家供大家参考,具体如下:

    martin fowler在《企业应用架构模式》一书中将我们平常接触到的应用开发分为三层:表现层、领域层和数据源层。

    其中领域层的领域逻辑模式有:事务脚本、领域模型以及表模块。

    1、事务脚本最容易理解也最易于开发,不过由于易造成代码重复等问题,不利于后期的维护,比较适合开发逻辑较为简单的业务,比如只有几个用于展示企业信息的企业站等;

    2、领域模型是三种模式中最为复杂的模式,缺点显而易见,需要较高的学习成本,不过优点也很鲜明,就是代码清晰,复用率高,便于后期的维护,比较适合用于复杂多变的应用情形下;

    3、表模块模式则介于事物脚本和领域模型之间,我们开发中小型项目时通常使用的都是表模块模式。

    好了,对于领域逻辑模式个人只有以上的粗浅理解,具体等以后加深理解了概念之后再来详谈。

    这里想跟大家说一说数据源层的数据源架构模式,主要有四种:表入口模式、行入口模式、活动记录和数据映射器。

    今天先讲最简单的表入口模式。

    书中对表入口模式的定义为:充当数据库表访问入口的对象,一个实例处理表中的所有行。

    可以理解为对之前分散在各个页面的sql语句进行封装,一张表就是一个对象,该对象处理所有与该表有关的业务逻辑,很好的提高了代码的复用性。

    现在想起来,当初刚毕业那会儿,经常使用表入口模式。

    具体的实现方式参见代码:

    database.php

    ?php
    class Database{
     //只是为了演示,通常情况下数据库的配置是会单独写在配置文件中的
     private static $_dbConfig = array(
     'host' => '127.0.0.1',
     'username' => 'root',
     'pwd' => '',
     'dbname' => 'bussiness'
     );
     private static $_instance;
     public static function getInstance(){
     if(is_null(self::$_instance)){
      self::$_instance = new mysqli(self::$_dbConfig['host'], self::$_dbConfig['username'], self::$_dbConfig['pwd'], self::$_dbConfig['dbname']);
      if(self::$_instance->connect_errno){
      throw new Exception(self::$_instance->connect_error);
      }
     }
     return self::$_instance;
     }
    }
    
    

    person.php

    ?php
    require_once 'database.php';
    class Person extends Database{
     public $instance;
     public $table = 'person';
     public function __construct(){
     $this->instance = Person::getInstance();
     }
     public function getPersonById($personId){
     $sql = "select * from $this->table where id=$personId";
     echo $sql;
     return $this->instance->query($sql);
     }
     /**其他的一些增删改查操作方法...**/
    }
    
    

    index.php

    ?php
    require_once 'person.php';
    $person = new Person();
    var_dump($person->getPersonById(1)->fetch_assoc());
    die();
    
    

    运行结果:

    select * from person where id=1
    array (size=2)
     'id' => string '1' (length=1)
     'name' => string 'ben' (length=3)
    
    

    更多关于PHP相关内容感兴趣的读者可查看本站专题:《php面向对象程序设计入门教程》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

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

    您可能感兴趣的文章:
    • PHP程序员简单的开展服务治理架构操作详解(三)
    • PHP程序员简单的开展服务治理架构操作详解(二)
    • PHP程序员简单的开展服务治理架构操作详解(一)
    • PHP架构及原理知识点详解
    • thinkPHP5.0框架整体架构总览【应用,模块,MVC,驱动,行为,命名空间等】
    • php代码架构的八点注意事项
    • 四种php中webservice实现的简单架构方法及实例
    • php之深入理解架构布局讲解
    上一篇:TP3.2.3框架文件上传操作实例详解
    下一篇:php面向对象基础详解【星际争霸游戏案例】
  • 相关文章
  • 

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

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

    PHP数据源架构模式之表入口模式实例分析 PHP,数据源,架构,模式,之表,