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 相关文章推荐
PHP4 与 MySQL 交互使用
Oct 09 PHP
php学习笔记 面向对象的构造与析构方法
Jun 13 PHP
深入理解curl类,可用于模拟get,post和curl下载
Jun 08 PHP
解析PHP高效率写法(详解原因)
Jun 20 PHP
利用中国天气预报接口实现简单天气预报
Jan 20 PHP
PHP中unset,array_splice删除数组中元素的区别
Jul 28 PHP
PHP防止刷新重复提交页面的示例代码
Nov 11 PHP
php实现购物车功能(下)
Jan 05 PHP
PHP函数shuffle()取数组若干个随机元素的方法分析
Apr 02 PHP
PHP支付系统设计与典型案例分享
Aug 02 PHP
jquery+thinkphp实现跨域抓取数据的方法
Oct 15 PHP
PHP实现的分解质因数操作示例
Aug 01 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快速生成各种信息提示框的方法
2016/02/03 PHP
Centos6.5和Centos7 php环境搭建方法
2016/05/27 PHP
针对多用户实现头像上传功能PHP代码 适用于登陆页面制作
2016/08/17 PHP
Yii框架防止sql注入,xss攻击与csrf攻击的方法
2016/10/18 PHP
js自带函数备忘 数组
2006/12/29 Javascript
Web Inspector:关于在 Sublime Text 中调试Js的介绍
2013/04/18 Javascript
javascript仿php的print_r函数输出json数据
2013/09/13 Javascript
setTimeout()与setInterval()方法区别介绍
2013/12/24 Javascript
JS仿iGoogle自定义首页模块拖拽特效的方法
2015/02/13 Javascript
JavaScript实现DIV层拖动及动态增加新层的方法
2015/05/12 Javascript
详解JavaScript中操作符和表达式
2018/09/12 Javascript
一篇文章,教你学会Vue CLI 插件开发
2019/04/17 Javascript
element-ui 文件上传修改文件名的方法示例
2019/11/05 Javascript
JavaScript 自定义html元素鼠标右键菜单功能
2019/12/02 Javascript
JS中间件设计模式的深入探讨与实例分析
2020/04/11 Javascript
[09:23]国际邀请赛采访专栏:iG战队VK,Tongfu战队Cu
2013/08/05 DOTA
Python 文件读写操作实例详解
2014/03/12 Python
Python实现二叉树前序、中序、后序及层次遍历示例代码
2019/05/18 Python
解决Django 在ForeignKey中出现 non-nullable field错误的问题
2019/08/06 Python
django-rest-swagger对API接口注释的方法
2019/08/29 Python
在 Python 中接管键盘中断信号的实现方法
2020/02/04 Python
详解三种方式实现平滑滚动页面到顶部的功能
2019/04/23 HTML / CSS
AmazeUI中各种的导航式菜单与解决方法
2020/08/19 HTML / CSS
经典的班主任推荐信
2013/10/28 职场文书
银行批评与自我批评
2014/02/10 职场文书
质检部经理岗位职责
2014/02/19 职场文书
年终总结会议主持词
2014/03/17 职场文书
施工安全责任书
2014/04/14 职场文书
2014年秋季开学寄语
2014/08/02 职场文书
优秀大学生事迹材料
2014/12/24 职场文书
考勤制度通知
2015/04/25 职场文书
新生儿未入户证明
2015/06/23 职场文书
python实现简单石头剪刀布游戏
2021/10/24 Python
【海涛解说】史上最给力比赛,挑战DOTA极限
2022/04/01 DOTA
Win10/Win11 任务栏替换成经典样式
2022/04/19 数码科技