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 相关文章推荐
实用函数8
Nov 08 PHP
防止本地用户用fsockopen DDOS攻击对策
Nov 02 PHP
PHP面向对象的进阶学习(抽像类、接口、final、类常量)
May 07 PHP
破解.net程序(dll文件)编译和反编译方法
Jan 31 PHP
php的SimpleXML方法读写XML接口文件实例解析
Jun 16 PHP
php header函数的常用http头设置
Jun 25 PHP
Zend Framework入门教程之Zend_Config组件用法详解
Dec 09 PHP
php查找字符串中第一个非0的位置截取
Feb 27 PHP
PHP简单实现合并2个数字键数组值的方法
May 30 PHP
PHP面向对象之工作单元(实例讲解)
Jun 26 PHP
PHP中递归的实现实例详解
Nov 14 PHP
Laravel中unique和exists验证规则的优化详解
Jan 28 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+MSSQL分页的例子
2006/10/09 PHP
一步一步学习PHP(2)――PHP类型
2010/02/15 PHP
php中模拟POST传递数据的两种方法分享
2011/09/16 PHP
php实现俄罗斯乘法实例
2015/03/07 PHP
推荐十款免费 WordPress 插件
2015/03/24 PHP
js技巧--转义符&quot;\&quot;的妙用
2007/01/09 Javascript
起点页面传值js,有空研究学习下
2010/01/25 Javascript
jquery load事件(callback/data)使用方法及注意事项
2013/02/06 Javascript
JavaScript获取按钮所在form表单id的方法
2015/04/02 Javascript
网页中JS函数自动执行常用三种方法
2016/03/30 Javascript
基于jQuery和hwSlider实现内容左右滑动切换效果附源码下载(一)
2016/06/22 Javascript
jQuery如何跳转到另一个网页 就这么简单
2016/12/28 Javascript
JavaScript中利用for循环遍历数组
2017/01/15 Javascript
JS Select下拉框(支持输入模糊查询)
2017/02/04 Javascript
Ext JS 实现建议词模糊动态搜索功能
2017/05/13 Javascript
AngularJS 支付倒计时功能实现思路
2017/06/05 Javascript
Bootstrap + AngularJS 实现简单的数据过滤字符查找功能
2017/07/27 Javascript
Vue.js移动端左滑删除组件的实现代码
2017/09/08 Javascript
浅谈Vue数据绑定的原理
2018/01/08 Javascript
关于vuejs中v-if和v-show的区别及v-show不起作用问题
2018/03/26 Javascript
使用uni-app开发微信小程序的实现
2019/12/13 Javascript
vue中v-model对select的绑定操作
2020/08/31 Javascript
Vue使用鼠标在Canvas上绘制矩形
2020/12/24 Vue.js
[02:02]DOTA2英雄基础教程 斯拉达
2013/12/11 DOTA
Python Numpy 数组的初始化和基本操作
2018/03/13 Python
python实现定时提取实时日志程序
2018/06/22 Python
Python + OpenCV 实现LBP特征提取的示例代码
2019/07/11 Python
Python趣味入门教程之循环语句while
2020/08/26 Python
python statsmodel的使用
2020/12/21 Python
Html5 Canvas实现图片标记、缩放、移动和保存历史状态功能 (附转换公式)
2020/03/18 HTML / CSS
联想阿根廷官方网站:Lenovo Argentina
2019/10/14 全球购物
学生发电厂实习自我鉴定
2013/09/22 职场文书
运动会闭幕式解说词
2014/02/21 职场文书
共青团员自我评价范文
2014/09/14 职场文书
美丽人生观后感
2015/06/03 职场文书
通过Python把学姐照片做成拼图游戏
2022/02/15 Python