0

0

ThinkPHP数据库查询之Db类场景分析

咔咔

咔咔

发布时间:2021-01-11 12:08:25

|

2117人浏览过

|

来源于php中文网

原创

终于快来到框架解析的结尾了,本文将会带领大家领略框架中的模型以及视图的奥秘。

前言

在日常开发过程中模型的使用是非常之多的,但是在开发过程只知道如何使用,并不知道内在是如何实现的,模型是不管接口还是后台都会使用到的东西。

关于视图在前后台分离的大趋势下,框架存在视图大多数还是针对于后台开发的使用。

本文也是对框架解读快到最后阶段了,接下来咔咔将带领大家一起学习关于在框架中Db类的奥秘。

下图为咔咔提供的脑图可以根据这个脑图进行阅读文章。

image.png
数据库执行流程

一、Db操作类和其它类对应关系解刨

在学习模型之前一定要知道的就是DB这个类,这个类也是对数据库的操作。

在框架中存在这样一个配置文件,在这个配置文件里边会存在关于数据库配置的一系列信息。

在接下来的过程中咔咔也会简单的创建一个数据库来做演示。

image.png
数据库配置文件

同样在框架的核心层存在俩个类,分别为Db类和Model类,这俩个类就是接下来的解析对象。

image.png
框架核心层需要知道的俩个类

在解析Db操作类和其它类对应关系解刨之前,我们先创建一个数据库作为演示使用。

image.png
演示数据库

首先先来看一下Db类的信息。

image.png
类的注释

通过上图我们可以看到关于Db类的一部分信息,就是使用Db类的一些查询方法。

但是来到Db类的最后可以看到一个熟悉的方法__callStatic

image.png
调用没有声明的静态方法

这个方法在一直读咔咔文章的读者应该已经很是熟悉了,这个方法在门面源码解析那一节中进行过深入的了解。

对于这个方法只需要记住的是在调用没有声明的静态方法时会进行调用。

至于call_user_func_array这个函数的使用可以理解为,这个方法是内置函数,可以直接调用函数运行,也就是可以直接运行方法。

image.png
门面类的源码

在通过刚刚的查看Db类的注释信息时可以看到Db类是使用着Connection这个类,也就是连接数据库类。

image.png
连接数据库类

进入到这个类里边简单的看一下构造函数即可,至于是怎么一个运行顺序会在下文进行讲解。

image.png
数据库配置数组创建Builder对象

在框架中操作控制器有俩大场景,第一中为Db类操作,第二种就是Model操作。

其中Connection·为连接器,Query为查询器,Builder为sql生成器,exception为异常类。

知道了以上的几个信息,在接下来的理解过程中会有一定的帮助,在下一节中将会对Db类库场景分析。

二、Db类库场景分析

先从一个简单的案例进行解析,先来看一下数据库的数据。

image.png
数据库模拟数据

然后来到控制器写一个简单的查询案例,在创建控制器之前先使用命令进行创建一个测试控制器。

image.png
创建的测试控制器

在这个控制器进行简单的查询数据。

image.png
使用简单的案例进行查询数据库数据

查询结果如下

image.png
查询结果

在这个案例中,可以看到使用的是Db::query这种查询方式,接下来对于这种查询方式进行简单的剖析。

接着执行流程就会来到Db这个类,在这个类中可以看到关于当对象访问不存在的静态方法时,__callStatic()方法会被自动调用。

这个方法在之前门面的讲解中进行了深度讲解。

image.png
Db类中的静态调用方法

从上图可以看到当执行访问对象不存在的静态方法时会执行到call_user_func_array调用回调函数,并把一个数组参数作为回调函数的参数

接着代码就会执行到static::connect()这行代码,由于本类Db没有继承任何的类,所以对于static这个的使用就是调用本类。

如果当Db类继承了其它类那么就会有一定的区别,这个区别就是关于static关键字,给大家做的一点点冷门知识得补充,当一个类继承一个类时,在父类实用static关键字时,默认调用的子类的方法。

切换数据库连接

因为没有任何继承,所以会来到本类的connect这个方法。

在这个类里边首先会返回结果为数据库配置信息。

然后会从配置信息中获取到query这个索引,最终返回\think\db\Query这个字符串,这里一定要注意返回的是字符串,不是这个类的实例。

紧接着就会执行到第三步创建数据库连接对象实例,接下里将会对这一步进行解析。

image.png
切换数据库连接

紧接着会来到文件实际执行的为 new \think\db\Query,最终会返回执行查询 返回数据集,返回数据为返回 object(think\db\Query)

关于这个$this->connection是在本类的构造函数进行设置的。

image.png
执行查询 返回数据集

先简单的看一下这个构造函数,在这个构造函数中直接就设置了connection这个属性的值,所以在上图中可以使用。

image.png
设置连接

在这里执行完成之后就会将返回的值给从一开始就解析的这个调用未声明的静态方法会进行调用。

其中static::connect()就是最终返回的值static::connect() 返回 object(think\db\Query)

image.png
静态方法调用

所以接下来代码会执行到  thinkphp/library/think/db/Query.php 的 query方法

$sql 就是在Db::query()中传递的sql语句,并且执行查询 返回数据集

最后这段代码会执行think\db\connector\Mysql的query方法

image.png
执行查询 返回数据集

接下来来到think\db\connector\Mysql的query方法

在这个方法中主要做了三件事情。

  • $this->initConnect 初始化数据库连接
  • $this->PDOStatement->execute(); 执行查询
  • return $this->getResult($pdo, $procedure); 返回结果集
image.png
执行查询 返回数据集

解析$this->initConnect 初始化数据库连接

在这个方法中可以看到是进行了一次配置信息获取,首先需要明白这个配置信息是什么。

image.png
初始化数据库连接

这个配置项是在配置文件database中配置的,根据注释提供的信息可以看到主要是关于主从服务器设置的。

一般情况下是不会在框架中配置主从信息的,这里就不去解析框架是如何实现数据库的主从配置了。

image.png
数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)

在这个判断中在进行了一次判断当前数据库连接的id,然后执行了连接数据库方法。

这个方法最终会返回object(PDO)#33的一个实例信息。

image.png
连接数据库方法

$this->PDOStatement->execute(); 执行查询

第二件事情做的就是执行查询,接下来我们来详细说明一下这个到底是如何执行的。

image.png
执行查询

在返回pdo实例时,将这个实例赋值给了$this->PDOStatement这个属性,所以会去PDO类中进行执行。

在这里大家需要明白一件事情就是关于execute这个方法,用于执行返回多个结果集、多个更新计数或二者组合的语句。

第三件事情返回结果集

直到这里就是执行的最后一步就是返回结果集。

这里使用的方法都是查询底层,就在去解析了,在这里就会返回最终查询结果。

image.png
获得数据集数组

最终结果就会返回给这里__callStatic方法,并且返回给上层的$res变量。

image.png
测试案例
image.png
最终查询结果

直到这里关于使用Db查询的执行流程就解析完了, 但是框架给封装的方法不仅仅只有query,其它的查询方式可以按照咔咔的这个流程在进行简单的分析。

最后执行的都会是这一节的最后几个流程,只是前边执行会有一点点区别而已。

坚持学习、坚持写博、坚持分享是咔咔从业以来一直所秉持的信念。希望在偌大互联网中咔咔的文章能带给你一丝丝帮助。我是咔咔,下期见。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

46

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

178

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

51

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

92

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

102

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

227

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

532

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

171

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号