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 相关文章推荐
Linux下ZendOptimizer的安装与配置方法
Apr 12 PHP
PHP Smarty生成EXCEL文档的代码
Aug 23 PHP
PHP 地址栏信息的获取代码
Jan 07 PHP
关于PHP堆栈与列队的学习
Jun 21 PHP
php 解压rar文件及zip文件的方法
May 05 PHP
PHP+MySQL修改记录的方法
Jan 21 PHP
Opcache导致php-fpm崩溃nginx返回502
Mar 02 PHP
PHP常用设计模式之委托设计模式
Feb 13 PHP
php合并数组并保留键值的实现方法
Mar 12 PHP
PHP将整数数字转换为罗马数字实例分享
Mar 17 PHP
Laravel基础-关于引入公共文件的两种方式
Oct 18 PHP
Thinkphp极验滑动验证码实现步骤解析
Nov 24 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 文件类型判断代码
2009/03/13 PHP
PHP批量采集下载美女图片的实现代码
2013/06/03 PHP
深入理解用mysql_fetch_row()以数组的形式返回查询结果
2013/06/05 PHP
wamp安装后自定义配置的方法
2014/08/23 PHP
php自定义错误处理用法实例
2015/03/20 PHP
Zend Framework教程之Zend_Layout布局助手详解
2016/03/04 PHP
JS模拟面向对象全解(一、类型及传递)
2011/07/13 Javascript
分享我对JS插件开发的一些感想和心得
2016/02/04 Javascript
jQuery插件DataTable使用方法详解(.Net平台)
2016/12/22 Javascript
详解vue-cli脚手架build目录中的dev-server.js配置文件
2017/11/24 Javascript
使用jQuery给Table动态增加行、清空table的方法
2018/09/05 jQuery
javascript实现鼠标点击生成文字特效
2019/12/24 Javascript
原生js实现弹窗消息动画
2020/11/20 Javascript
[01:23]2019完美世界全国高校联赛(春季赛)合肥全国总决赛
2019/06/10 DOTA
python pdb调试方法分享
2014/01/21 Python
python实现文件快照加密保护的方法
2015/06/30 Python
python基础练习之几个简单的游戏
2017/11/10 Python
python搭建服务器实现两个Android客户端间收发消息
2018/04/12 Python
PyQt实现界面翻转切换效果
2018/04/20 Python
python3+PyQt5实现支持多线程的页面索引器应用程序
2018/04/20 Python
OpenCV HSV颜色识别及HSV基本颜色分量范围
2019/03/22 Python
python3中property使用方法详解
2019/04/23 Python
css3背景_动力节点Java学院整理
2017/07/11 HTML / CSS
纯CSS3实现运行时钟的示例代码
2021/01/25 HTML / CSS
夏威夷航空官网:Hawaiian Airlines
2016/09/11 全球购物
美国手工艺品市场的领导者:Annie’s
2019/04/04 全球购物
毕业生动漫设计求职信
2013/10/11 职场文书
中国梦读书活动总结
2014/07/10 职场文书
工地例会施工汇报材料
2014/08/22 职场文书
讲文明知礼仪演讲稿
2014/09/13 职场文书
碧霞祠导游词
2015/02/09 职场文书
2015年收银工作总结范文
2015/04/01 职场文书
《暗黑破坏神2:重制版》本周进行第一轮A测 目前可官网进行申请报名
2021/04/07 其他游戏
使用Redis实现实时排行榜功能
2021/07/02 Redis
Mysql外键约束的创建与删除的使用
2022/03/03 MySQL
springboot为异步任务规划自定义线程池的实现
2022/06/14 Java/Android