ThinkPHP数据库查询之Db类场景分析
发布时间 - 2021-01-11 00:00:00 点击率:次“终于快来到框架解析的结尾了,本文将会带领大家领略框架中的模型以及视图的奥秘。
”
前言
在日常开发过程中模型的使用是非常之多的,但是在开发过程只知道如何使用,并不知道内在是如何实现的,模型是不管接口还是后台都会使用到的东西。
关于视图在前后台分离的大趋势下,框架存在视图大多数还是针对于后台开发的使用。
本文也是对框架解读快到最后阶段了,接下来咔咔将带领大家一起学习关于在框架中Db类的奥秘。
下图为咔咔提供的脑图可以根据这个脑图进行阅读文章。
一、Db操作类和其它类对应关系解刨
在学习模型之前一定要知道的就是DB这个类,这个类也是对数据库的操作。
在框架中存在这样一个配置文件,在这个配置文件里边会存在关于数据库配置的一系列信息。
在接下来的过程中咔咔也会简单的创建一个数据库来做演示。
同样在框架的核心层存在俩个类,分别为Db类和Model类,这俩个类就是接下来的解析对象。
在解析Db操作类和其它类对应关系解刨之前,我们先创建一个数据库作为演示使用。
首先先来看一下Db类的信息。
通过上图我们可以看到关于Db类的一部分信息,就是使用Db类的一些查询方法。
但是来到Db类的最后可以看到一个熟悉的方法__callStatic。
这个方法在一直读咔咔文章的读者应该已经很是熟悉了,这个方法在门面源码解析那一节中进行过深入的了解。
对于这个方法只需要记住的是在调用没有声明的静态方法时会进行调用。
至于call_user_func_array这个函数的使用可以理解为,这个方法是内置函数,可以直接调用函数运行,也就是可以直接运行方法。
在通过刚刚的查看Db类的注释信息时可以看到Db类是使用着Connection这个类,也就是连接数据库类。
进入到这个类里边简单的看一下构造函数即可,至于是怎么一个运行顺序会在下文进行讲解。
在框架中操作控制器有俩大场景,第一中为Db类操作,第二种就是Model操作。
其中Connection·为连接器,Query为查询器,Builder为sql生成器,exception为异常类。
知道了以上的几个信息,在接下来的理解过程中会有一定的帮助,在下一节中将会对Db类库场景分析。
二、Db类库场景分析
先从一个简单的案例进行解析,先来看一下数据库的数据。
然后来到控制器写一个简单的查询案例,在创建控制器之前先使用命令进行创建一个测试控制器。
在这个控制器进行简单的查询数据。
查询结果如下
在这个案例中,可以看到使用的是Db::query这种查询方式,接下
来对于这种查询方式进行简单的剖析。
接着执行流程就会来到Db这个类,在这个类中可以看到关于当对象访问不存在的静态方法时,__callStatic()方法会被自动调用。
这个方法在之前门面的讲解中进行了深度讲解。
从上图可以看到当执行访问对象不存在的静态方法时会执行到call_user_func_array调用回调函数,并把一个数组参数作为回调函数的参数
接着代码就会执行到static::connect()这行代码,由于本类Db没有继承任何的类,所以对于static这个的使用就是调用本类。
如果当Db类继承了其它类那么就会有一定的区别,这个区别就是关于static关键字,给大家做的一点点冷门知识得补充,当一个类继承一个类时,在父类实用static关键字时,默认调用的子类的方法。
切换数据库连接
因为没有任何继承,所以会来到本类的connect这个方法。
在这个类里边首先会返回结果为数据库配置信息。
然后会从配置信息中获取到query这个索引,最终返回\think\db\Query这个字符串,这里一定要注意返回的是字符串,不是这个类的实例。
紧接着就会执行到第三步创建数据库连接对象实例,接下里将会对这一步进行解析。
紧接着会来到文件实际执行的为 new \think\db\Query,最终会返回执行查询 返回数据集,返回数据为返回 object(think\db\Query)
关于这个$this->connection是在本类的构造函数进行设置的。
先简单的看一下这个构造函数,在这个构造函数中直接就设置了connection这个属性的值,所以在上图中可以使用。
在这里执行完成之后就会将返回的值给从一开始就解析的这个调用未声明的静态方法会进行调用。
其中static::connect()就是最终返回的值static::connect() 返回 object(think\db\Query)。
所以接下来代码会执行到 thinkphp/library/think/db/Query.php 的 query方法
$sql 就是在Db::query()中传递的sql语句,并且执行查询 返回数据集
最后这段代码会执行think\db\connector\Mysql的query方法
接下来来到think\db\connector\Mysql的query方法
在这个方法中主要做了三件事情。
$this->initConnect初始化数据库连接$this->PDOStatement->execute();执行查询return $this->getResult($pdo, $procedure);返回结果集
解析$this->initConnect 初始化数据库连接
在这个方法中可以看到是进行了一次配置信息获取,首先需要明白这个配置信息是什么。
这个配置项是在配置文件database中配置的,根据注释提供的信息可以看到主要是关于主从服务器设置的。
一般情况下是不会在框架中配置主从信息的,这里就不去解析框架是如何实现数据库的主从配置了。
在这个判断中在进行了一次判断当前数据库连接的id,然后执行了连接数据库方法。
这个方法最终会返回object(PDO)#33的一个实例信息。
$this->PDOStatement->execute(); 执行查询
第二件事情做的就是执行查询,接下来我们来详细说明一下这个到底是如何执行的。
在返回pdo实例时,将这个实例赋值给了$this->PDOStatement这个属性,所以会去PDO类中进行执行。
在这里大家需要明白一件事情就是关于execute这个方法,用于执行返回多个结果集、多个更新计数或二者组合的语句。
第三件事情返回结果集
直到这里就是执行的最后一步就是返回结果集。
这里使用的方法都是查询底层,就在去解析了,在这里就会返回最终查询结果。
最终结果就会返回给这里__callStatic方法,并且返回给上层的$res变量。
直到这里关于使用Db查询的执行流程就解析完了, 但是框架给封装的方法不仅仅只有query,其它的查询方式可以按照咔咔的这个流程在进行简单的分析。
最后执行的都会是这一节的最后几个流程,只是前边执行会有一点点区别而已。
“坚持学习、坚持写博、坚持分享是咔咔从业以来一直所秉持的信念。希望在偌大互联网中咔咔的文章能带给你一丝丝帮助。我是咔咔,下期见。
”
# thinkphp
# 编辑器
# 在这个
# 可以看到
# 就会
# 咔咔
# 本类
# 是在
# 看一下
# 在这里
# 查询结果
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何快速配置高效服务器建站软件?
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置
Laravel如何优化应用性能?(缓存和优化命令)
Linux网络带宽限制_tc配置实践解析【教程】
想要更高端的建设网站,这些原则一定要坚持!
Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】
详解MySQL数据库的安装与密码配置
网易LOFTER官网链接 老福特网页版登录地址
Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道
Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】
高端建站三要素:定制模板、企业官网与响应式设计优化
网站建设保证美观性,需要考虑的几点问题!
INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】
Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复
Laravel怎么实现支付功能_Laravel集成支付宝微信支付
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
Laravel如何配置任务调度?(Cron Job示例)
高端网站建设与定制开发一站式解决方案 中企动力
laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程
佛山企业网站制作公司有哪些,沟通100网上服务官网?
Python面向对象测试方法_mock解析【教程】
Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布
jQuery 常见小例汇总
如何用AWS免费套餐快速搭建高效网站?
Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】
如何在自有机房高效搭建专业网站?
Mybatis 中的insertOrUpdate操作
图册素材网站设计制作软件,图册的导出方式有几种?
linux写shell需要注意的问题(必看)
PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】
JS碰撞运动实现方法详解
C#如何调用原生C++ COM对象详解
Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程
在centOS 7安装mysql 5.7的详细教程
Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明
如何获取上海专业网站定制建站电话?
长沙做网站要多少钱,长沙国安网络怎么样?
南京网站制作费用,南京远驱官方网站?
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
网站制作大概多少钱一个,做一个平台网站大概多少钱?
JavaScript如何实现错误处理_try...catch如何捕获异常?
如何在服务器上配置二级域名建站?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
BootStrap整体框架之基础布局组件
如何快速启动建站代理加盟业务?
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】

