当前位置:  开发笔记 > 编程语言 > 正文

一步步编写PHP的Framework(十六)

我把模型分成了几块儿,A,B,C,D,E,F,这几块儿分别代表了什么呢?首先A,这个Base代表的就是整个框架的基类,所有的模型文件都必须继承自这个基类;由于B的内容需要依赖D,所以先说一下D,D首先有一...">

 

我把模型分成了几块儿,A,B,C,D,E,F,这几块儿分别代表了什么呢?

\

      首先A,这个Base代表的就是整个框架的基类,所有的模型文件都必须继承自这个基类;

      由于B的内容需要依赖D,所以先说一下D,D首先有一个ConnectionManager,它负责管理数据库的连接和关闭还有数据库驱动的选择,这个命名自己感觉不太好,先就将就吧,既然它负责数据库的连接和关闭,肯定它就有以下方法:

1
2 public class ConnectionManager {
3    public static function getConnection(){}
4    public static function releaseConnection() {}
5 }

 

     由于数据库的连接对于所有模型来说都是共享的,所以我们把ConnnectionManager设置为单例。

     D中右边有PDO,MYSQL_*,这代表什么意思呢,实际上就是代表各种驱动,有可能你使用的是比较先进的PDO,也有可能你使用的是比较老的MYSQL_*这种,也有可能你使用的是mysqli,ADO等等,正是由于PHP数据库这一块儿的混乱情况,我们需要在框架中定义一个契约,所有的驱动类按照这个契约编写实现,这样,不管驱动类的底层实现怎样,但是上层看到的内容都是一致的。

     现在我们定义一下这个契约:

01
02 interface IDbDriver {
03     function execute($sql);
04     function connect();
05     function close();
06     function getAllByObject();
07     function getAllByAssocArray();
08     function getAllByArray();
09     function beginTrans();
10     function commit();
11     function rollback();
12 }

 

      connect就是连接数据库,execute就是执行一个SQL,如果这个SQL是一个查询,那么getAllByObject代表将查询的结果通过对象返回,getAllByAssocArray代表将结果按照关联数组返回,getAllByArray代表将结果按照普通数组返回,beginTrans代表开启一个事务,即开启autoCommit,commit就是提交事务,rollback是将事务回滚,close就是关闭Db。

      其实,在将查询的结果返回的时候,还可以封装成为一个iterator。

       好,我们现在再来看看B,首先看看ModelBase,它实际上是提供给表模型和关系模型使用的,它封装了外部可见的各种函数,如query,insert,update,delete,execute,fetchAll等等,那也就是说B中所有的驱动类外部都是不可以直接访问的,那么谁访问呢,就是ModelBase,但是它又不直接访问,而是通过ConnectionManager来访问。

       由于ConnectionManager会按照配置文件自动选择驱动,所以ModelBase也不知道到底它调用的是哪一个驱动类,但是由于驱动类都遵循契约,所以ModelBase不用管到底是那个驱动,就可调用契约上面的方法了。

01
02 class ModelBase extends Base {
03     protected $_db = null;
04     public function __construct() {
05         $this->_db = ConnectionManager::getConnection();
06     }
07     public function execute($sql) {
08         $this->_db->execute($sql);
09     }
10 }

 

       就比如上面这段代码,首先在实例化ModelBase的时候,就会调用ConnectionManager的getConnection获取数据库的连接,当然,由于ConnectionManager是单例的,所以即使同时实例化了10个ModelBase类,数据库的连接操作也只有一次。

       由于有了上面的契约,在这一层执行一个SQL非常简单,只要调用驱动类的execute方法即可,即$this->_db->execute($sql);

       说了ModelBase,再说一下SQL Parse,它主要的功能就是完成SQL的解析,什么时候需要SQL的解析呢,实现数据库的ORM的时候。

       这一层也是由ModelBase调用的,假设现在外部有一个查询操作,调用的方式是$this->where()->order()->select(),当然,每个函数的参数我都没写,这种函数链非常友好,SQL Parse就会去解析这几个函数的实际意义,然后返回给ModelBase,ModelBase拿到解析之后的SQL,然后执行$this->_db->execute($sql)即可,所以不管花样是那样,最终都还是调用了驱动类的execute方法执行一条SQL的。

       下面的C实际上就容易理解了,就是表模型和关系模型,由于一些操作在ModelBase中已经做完了,所以只要表模型和关系模型继承ModelBase即可。表模型由于处理的是单表的内容,所以它有额外的内容,比如在执行一个$this->select()的时候 ,我们没有指定查询的内容,系统应该能够识别它要查询的表是什么,可能最终解析的SQL就是:select * from XXX了,关系模型也是一样。

        说完了C,E也很容易理解,模型这一层实际上就是调用关系模型或者表模型的方法实现具体的业务即可。

        F中是处理和普通数据库以外的其他内容,比如Cache,由于这里只是讲一下思路,所以这块儿的内容暂时不写,如果有时间就后面再讲,如果没有,那就算了。


推荐阅读
  • 本文深入探讨了原型模式在软件设计中的应用与实现。原型模式通过使用已有的实例作为原型来创建新对象,而不是直接通过类实例化。这种方式不仅简化了对象的创建过程,还提高了系统的灵活性和效率。具体来说,原型模式涉及一个支持克隆功能的接口或基类,子类通过实现该接口来提供具体的克隆方法,从而实现对象的快速复制。此外,文章还详细分析了原型模式的优缺点及其在实际项目中的应用场景,为开发者提供了实用的指导和建议。 ... [详细]
  • 本文详细探讨了Java集合框架的使用方法及其性能特点。首先,通过关系图展示了集合接口之间的层次结构,如`Collection`接口作为对象集合的基础,其下分为`List`、`Set`和`Queue`等子接口。其中,`List`接口支持按插入顺序保存元素且允许重复,而`Set`接口则确保元素唯一性。此外,文章还深入分析了不同集合类在实际应用中的性能表现,为开发者选择合适的集合类型提供了参考依据。 ... [详细]
  • 在《PHP应用性能优化实战指南:从理论到实践的全面解析》一文中,作者分享了一次实际的PHP应用优化经验。文章回顾了先前进行的一次优化项目,指出即使系统运行时间较长后出现的各种问题和性能瓶颈,通过采用一些通用的优化策略仍然能够有效解决。文中不仅详细阐述了优化的具体步骤和方法,还结合实例分析了优化前后的性能对比,为读者提供了宝贵的参考和借鉴。 ... [详细]
  • Vuex 实战进阶:构建高效笔记本应用(第二篇)
    在上一篇文章中,我们初步探讨了 Vuex 在该项目中的应用。本文将深入解析整个项目的架构设计。首先回顾 `main.js` 的内容,然后重点分析 `App.vue` 文件,其中引入了 `Toolbar.vue` 和 `NodeList.vue` 组件,详细说明它们在应用中的作用和交互方式。通过这些组件的协同工作,我们将展示如何构建一个高效且响应迅速的笔记本应用。 ... [详细]
  • Photoshop教程第五讲:使用套索工具精准抠图技巧
    在本节Photoshop教程中,我们将深入探讨如何利用套索工具实现精准的图像抠图。通过详细的操作步骤和实用技巧,帮助用户掌握套索工具的多种使用方法,提升图像处理的精细度和效率。 ... [详细]
  • 本文作为“实现简易版Spring系列”的第五篇,继前文深入探讨了Spring框架的核心技术之一——控制反转(IoC)之后,将重点转向另一个关键技术——面向切面编程(AOP)。对于使用Spring框架进行开发的开发者来说,AOP是一个不可或缺的概念。了解AOP的背景及其基本原理,对于掌握这一技术至关重要。本文将通过具体示例,详细解析AOP的实现机制,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 本文详细解析了如何使用 jQuery 实现一个在浏览器地址栏运行的射击游戏。通过源代码分析,展示了关键的 JavaScript 技术和实现方法,并提供了在线演示链接供读者参考。此外,还介绍了如何在 Visual Studio Code 中进行开发和调试,为开发者提供了实用的技巧和建议。 ... [详细]
  • 本文首先对信息漏洞的基础知识进行了概述,重点介绍了几种常见的信息泄露途径。具体包括目录遍历、PHPINFO信息泄露以及备份文件的不当下载。其中,备份文件下载涉及网站源代码、`.bak`文件、Vim缓存文件和`DS_Store`文件等。目录遍历漏洞的详细分析为后续深入研究奠定了基础。 ... [详细]
  • React组件是构成用户界面的基本单元,每个组件都封装了特定的功能和逻辑,具备高度的独立性和可复用性。通过将不同大小和功能的组件组合在一起,可以构建出复杂且功能丰富的页面,类似于拼图游戏中的各个部分,最终形成一个完整的视觉效果。 ... [详细]
  • 在面对不确定性的挑战时,卓越的操作者通常会采用七大策略来有效管理和减轻风险,这些策略同样适用于职业发展和个人生活。具体而言,这七大风险管理策略包括:1. 克服恐惧心理卓越的操作者能够正视并克服内心的恐惧,保持冷静和理性,从而做出更加明智的决策。这一能力不仅有助于在市场波动中保持稳定,也能在职业生涯和个人生活中发挥重要作用。 ... [详细]
  • 《题画山水屏风》译文与原文赏析:唐代诗人张九龄的艺术解读 ... [详细]
  • 《已亥杂诗 第139首》译文与原文鉴赏:清代文学家龚自珍的诗歌艺术探析 ... [详细]
  • 配置未被正确应用:导航栏图标设置失效问题分析与解决 ... [详细]
  • 新年伊始,正是学习的最佳时机。本文全面解析了CK1957-Zookeeper的核心概念与实践技巧,旨在帮助初学者快速掌握这一深度学习工具。通过详细的理论讲解和实际操作示例,读者可以更好地理解Zookeeper的工作原理及其在分布式系统中的应用。无论是新手还是有一定基础的学习者,都能从中受益匪浅。 ... [详细]
  • 微信支付授权目录配置详解及操作步骤
    在使用微信支付时,若通过WeixinJSBridge.invoke方法调用支付功能,可能会遇到“当前页面URL未注册”的错误提示,导致get_brand_wcpay_request:fail调用微信JSAPI支付失败。为解决这一问题,需要正确配置微信支付授权目录,确保支付页面的URL已成功注册。本文将详细介绍微信支付授权目录的配置步骤和注意事项,帮助开发者顺利完成支付功能的集成与调试。 ... [详细]
author-avatar
wodewodewoe
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有