当前位置:首页 > PHP教程 > php高级应用 > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2022-02-07 10:40:17 浏览: 评论:0 

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

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

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

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

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

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

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

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

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

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

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

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

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

database.php

  1. <?php 
  2. class Database{ 
  3.  //只是为了演示,通常情况下数据库的配置是会单独写在配置文件中的 
  4.  private static $_dbConfig = array
  5.  'host' => '127.0.0.1'
  6.  'username' => 'root'
  7.  'pwd' => ''
  8.  'dbname' => 'bussiness' 
  9.  ); 
  10.  private static $_instance
  11.  public static function getInstance(){ 
  12.  if(is_null(self::$_instance)){ 
  13.   self::$_instance = new mysqli(self::$_dbConfig['host'], self::$_dbConfig['username'], self::$_dbConfig['pwd'], self::$_dbConfig['dbname']); 
  14.   if(self::$_instance->connect_errno){ 
  15.   throw new Exception(self::$_instance->connect_error); 
  16.   } 
  17.  } 
  18.  return self::$_instance
  19.  } 

person.php

  1. <?php 
  2. require_once 'database.php'
  3. class Person extends Database{ 
  4.  public $instance
  5.  public $table = 'person'
  6.  public function __construct(){ 
  7.  $this->instance = Person::getInstance(); 
  8.  } 
  9.  public function getPersonById($personId){ 
  10.  $sql = "select * from $this->table where id=$personId"
  11.  echo $sql
  12.  return $this->instance->query($sql); 
  13.  } 
  14.  /**其他的一些增删改查操作方法...**/ 

index.php

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

运行结果:

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

Tags: PHP数据源架构模式

分享到: