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 程序员应该使用的10个组件
Oct 31 PHP
使用PHP实现密保卡功能实现代码&amp;lt;打包下载直接运行&amp;gt;
Oct 09 PHP
如何获知PHP程序占用多少内存(memory_get_usage)
Sep 23 PHP
解析PHP缓存函数的使用说明
May 10 PHP
ThinkPHP3.1新特性之查询条件预处理简介
Jun 19 PHP
自己写的兼容低于PHP 5.5版本的array_column()函数
Oct 24 PHP
PHP采用curl模仿用户登陆新浪微博发微博的方法
Nov 07 PHP
php强制更新图片缓存的方法
Feb 11 PHP
php实现将数组转换为XML的方法
Mar 09 PHP
PHP对象克隆clone用法示例
Sep 28 PHP
浅谈PHP发送HTTP请求的几种方式
Jul 25 PHP
php学习笔记之字符串常见操作总结
Jul 16 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边学边教》(04.编写简易的通讯录――视频教程1)
2006/12/13 PHP
php中使用ExcelFileParser处理excel获得数据(可作批量导入到数据库使用)
2010/08/21 PHP
php中常用的预定义变量小结
2012/05/09 PHP
PHPer 需要了解的 5 个 Composer 小技巧
2014/08/18 PHP
PHP实现链式操作的核心思想
2015/06/23 PHP
PHP上传图片时判断上传文件是否为可用图片的方法
2016/10/20 PHP
利用PHP判断文件是否为图片的方法总结
2017/01/06 PHP
PHP 计算两个特别大的整数实例代码
2018/05/07 PHP
PHP中Static(静态)关键字功能与用法实例分析
2019/04/05 PHP
控制文字内容的显示与隐藏示例
2014/06/11 Javascript
js实现网页标题栏闪烁提示效果实例分析
2014/11/20 Javascript
深入理解jquery自定义动画animate()
2016/05/24 Javascript
jQuery实现的网格线绘制方法
2016/06/20 Javascript
AngularJS教程之环境设置
2016/08/16 Javascript
Bootstrap基本插件学习笔记之折叠(22)
2016/12/08 Javascript
Vue组件模板形式实现对象数组数据循环为树形结构(实例代码)
2017/07/31 Javascript
jQuery实现简单的回到顶部totop功能示例
2017/10/16 jQuery
基于node搭建服务器,写接口,调接口,跨域的实例
2018/05/13 Javascript
JavaScript编码小技巧分享
2020/09/17 Javascript
antd design table更改某行数据的样式操作
2020/10/31 Javascript
详解pandas如何去掉、过滤数据集中的某些值或者某些行?
2019/05/15 Python
django项目用higcharts统计最近七天文章点击量
2019/08/17 Python
解决Django layui {{}}冲突的问题
2019/08/29 Python
Python 变量的创建过程详解
2019/09/02 Python
解决jupyter notebook打不开无反应 浏览器未启动的问题
2020/04/10 Python
Manjaro、pip、conda更换国内源的方法
2020/11/17 Python
python中温度单位转换的实例方法
2020/12/27 Python
全球虚拟主机商:HostGator
2017/02/06 全球购物
梅花魂教学反思
2014/04/25 职场文书
员工薪酬激励方案
2014/06/13 职场文书
陈胜吴广起义口号
2014/06/20 职场文书
五年级上册复习计划
2015/01/19 职场文书
刑事附带民事起诉状
2015/05/19 职场文书
领导莅临指导欢迎词
2015/09/30 职场文书
高一作文之乐趣
2019/11/21 职场文书
MySQL高速缓存启动方法及参数详解(query_cache_size)
2021/07/01 MySQL