ThinkPHP数据库查询之Db类深度解析(2)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: ThinkPHP数据库查询之Db类深度解析

二、Db类库场景分析

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


image.png


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


image.png


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


image.png


查询结果如下


image.png


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


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


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


image.png


从上图可以看到当执行访问对象不存在的静态方法时会执行到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


在这个判断中在进行了一次判断当前数据库连接的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,其它的查询方式可以按照咔咔的这个流程在进行简单的分析。


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


相关文章
|
6天前
|
SQL 关系型数据库 MySQL
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
课程分类查询、课程新增、统一异常处理、统一封装结果类、JSR303校验、修改课程、查询课程计划、新增/修改课程计划
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
|
6天前
|
前端开发 应用服务中间件 API
|
14天前
|
存储 关系型数据库 MySQL
如何优化数据库查询?
如何优化数据库查询?
33 1
|
6天前
|
SQL 存储 数据库
MSSQL遍历数据库根据列值查询数据
【9月更文挑战第12天】在 SQL Server 中,可以通过游标或临时表遍历数据库并根据列值查询数据。示例展示了如何创建临时表存储数据库名,并通过循环遍历这些名称来执行特定查询。需替换 `YourTableName`、`YourColumnName` 和 `YourValue` 为实际值。此方法要求有足够权限访问各数据库。若无跨库权限,需分别执行查询。
|
7天前
|
SQL 关系型数据库 MySQL
MySQL技术安装配置、数据库与表的设计、数据操作解析
MySQL,作为最流行的关系型数据库管理系统之一,在WEB应用领域中占据着举足轻重的地位。本文将从MySQL的基本概念、安装配置、数据库与表的设计、数据操作解析,并通过具体的代码示例展示如何在实际项目中应用MySQL。
33 0
|
19天前
|
存储 C# 关系型数据库
“云端融合:WPF应用无缝对接Azure与AWS——从Blob存储到RDS数据库,全面解析跨平台云服务集成的最佳实践”
【8月更文挑战第31天】本文探讨了如何将Windows Presentation Foundation(WPF)应用与Microsoft Azure和Amazon Web Services(AWS)两大主流云平台无缝集成。通过具体示例代码展示了如何利用Azure Blob Storage存储非结构化数据、Azure Cosmos DB进行分布式数据库操作;同时介绍了如何借助Amazon S3实现大规模数据存储及通过Amazon RDS简化数据库管理。这不仅提升了WPF应用的可扩展性和可用性,还降低了基础设施成本。
42 0
|
19天前
|
Java 数据库连接 数据库
AI 时代风起云涌,Hibernate 实体映射引领数据库高效之路,最佳实践与陷阱全解析!
【8月更文挑战第31天】Hibernate 是一款强大的 Java 持久化框架,可将 Java 对象映射到关系数据库表中。本文通过代码示例详细介绍了 Hibernate 实体映射的最佳实践,包括合理使用关联映射(如 `@OneToMany` 和 `@ManyToOne`)以及正确处理继承关系(如单表继承)。此外,还探讨了常见陷阱,例如循环依赖可能导致的无限递归问题,并提供了使用 `@JsonIgnore` 等注解来避免此类问题的方法。通过遵循这些最佳实践,可以显著提升开发效率和数据库操作性能。
41 0
|
19天前
|
SQL 数据库 Java
HQL vs SQL:谁将统治数据库查询的未来?揭秘Hibernate的神秘力量!
【8月更文挑战第31天】Hibernate查询语言(HQL)是一种面向对象的查询语言,它模仿了SQL的语法,但操作对象为持久化类及其属性,而非数据库表和列。HQL具有类型安全、易于维护等优点,支持面向对象的高级特性,内置大量函数,可灵活处理查询结果。下面通过示例对比HQL与SQL,展示HQL在实际应用中的优势。例如,HQL查询“从员工表中筛选年龄大于30岁的员工”只需简单地表示为 `FROM Employee e WHERE e.age > 30`,而在SQL中则需明确指定表名和列名。此外,HQL在处理关联查询时也更为直观易懂。然而,对于某些复杂的数据库操作,SQL仍有其独特优势。
26 0
|
19天前
|
API Java 数据库连接
从平凡到卓越:Hibernate Criteria API 让你的数据库查询瞬间高大上,彻底告别复杂SQL!
【8月更文挑战第31天】构建复杂查询是数据库应用开发中的常见需求。Hibernate 的 Criteria API 以其强大和灵活的特点,允许开发者以面向对象的方式构建查询逻辑,同时具备 SQL 的表达力。本文将介绍 Criteria API 的基本用法并通过示例展示其实际应用。此 API 通过 API 构建查询条件而非直接编写查询语句,提高了代码的可读性和安全性。无论是简单的条件过滤还是复杂的分页和连接查询,Criteria API 均能胜任,有助于提升开发效率和应用的健壮性。
34 0
|
21天前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件

热门文章

最新文章

推荐镜像

更多