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


Posted in PHP onJanuary 23, 2020

本文实例讲述了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中利用XML技术构造远程服务(下)
Oct 09 PHP
php读取msn上的用户信息类
Dec 05 PHP
同台服务器使用缓存APC效率高于Memcached的演示代码
Feb 16 PHP
php 文件缓存函数
Oct 08 PHP
遭遇php的in_array低性能问题
Sep 17 PHP
ThinkPHP之N方法实例详解
Jun 20 PHP
php解析json数据实例
Aug 19 PHP
跟我学Laravel之视图 &amp; Response
Oct 15 PHP
thinkPHP简单导入和使用阿里云OSSsdk的方法
Mar 15 PHP
PHP封装的非对称加密RSA算法示例
May 28 PHP
php根据地址获取百度地图经纬度的实例方法
Sep 03 PHP
TP3.2.3框架文件上传操作实例详解
Jan 23 #PHP
php的RSA加密解密算法原理与用法分析
Jan 23 #PHP
PHP检查文件是否存在,不存在自动创建及读取文件内容操作示例
Jan 23 #PHP
PHP实现一个按钮点击上传多个图片操作示例
Jan 23 #PHP
利用PHP内置SERVER开启web服务(本地开发使用)
Jan 22 #PHP
PHP读取文件,解决中文乱码UTF-8的方法分析
Jan 22 #PHP
php经典趣味算法实例代码
Jan 21 #PHP
You might like
字母顺序颠倒而单词顺序不变的php代码
2010/08/08 PHP
PHP在字符断点处截断文字的实现代码
2011/04/21 PHP
使用array mutisort 实现按某字段对数据排序
2013/06/18 PHP
优化WordPress中文章与评论的时间显示
2016/01/12 PHP
PHP 的Opcache加速的使用方法
2017/12/29 PHP
PHP abstract 抽象类定义与用法示例
2018/05/29 PHP
php 将json格式数据转换成数组的方法
2018/08/21 PHP
laravel 实现关闭CSRF(全部关闭、部分关闭)
2019/10/21 PHP
加速IE的Javascript document输出的方法
2010/12/02 Javascript
jQuery学习笔记[1] jQuery中的DOM操作
2010/12/03 Javascript
jQuery 选择表格(table)里的行和列及改变简单样式
2012/12/15 Javascript
一个字符串反转函数可实现字符串倒序
2014/09/15 Javascript
Javascript基础教程之关键字和保留字汇总
2015/01/18 Javascript
JavaScript数据结构之二叉查找树的定义与表示方法
2017/04/12 Javascript
three.js中文文档学习之通过模块导入
2017/11/20 Javascript
解析vue路由异步组件和懒加载案例
2018/06/08 Javascript
create-react-app安装出错问题解决方法
2018/09/04 Javascript
JavaScript面向对象编程小游戏---贪吃蛇代码实例
2019/05/15 Javascript
2019最新21个MySQL高频面试题介绍
2020/02/06 Javascript
布同 Python中文问题解决方法(总结了多位前人经验,初学者必看)
2011/03/13 Python
一个超级简单的python web程序
2014/09/11 Python
初步介绍Python中的pydoc模块和distutils模块
2015/04/13 Python
利用Python破解斗地主残局详解
2017/06/30 Python
python 将字符串转换成字典dict的各种方式总结
2018/03/23 Python
在cmder下安装ipython以及环境的搭建
2018/10/19 Python
python使用正则筛选信用卡
2019/01/27 Python
I.T中国官网:精选时尚设计师单品网购平台
2018/03/26 全球购物
房地产销售计划书
2014/01/10 职场文书
法律七进实施方案
2014/03/15 职场文书
网络信息安全承诺书
2014/03/26 职场文书
小学优秀教育工作者事迹材料
2014/05/09 职场文书
幸福家庭事迹材料
2014/12/20 职场文书
赢在中国观后感
2015/06/02 职场文书
高二化学教学反思
2016/02/22 职场文书
你会写请假条吗?
2019/06/26 职场文书
详解Laravel服务容器的优势
2021/05/29 PHP