网站首页 > 技术文章 正文
在SQL中,SELECT 语句的各个部分(如 SELECT、FROM、WHERE、GROUP BY、HAVING 等)有其特定的执行顺序,但这并不完全等同于它们在SQL语句中的物理顺序。以下是这些部分的逻辑执行顺序(也被称为查询的执行计划或查询处理的步骤):
- FROM 和 JOIN数据库首先确定要从哪些表中检索数据,并执行任何必要的表连接操作。
- WHERE接下来,数据库会应用 WHERE 子句中的条件来过滤掉不满足条件的行。
- GROUP BY然后,数据库会根据 GROUP BY 子句中指定的列对结果进行分组。
- 聚合函数(如 SUM(), COUNT(), AVG() 等)在分组后,数据库会计算任何在 SELECT 语句中指定的聚合函数。
- HAVING在应用了聚合函数之后,HAVING 子句会进一步过滤掉不满足其条件的组。注意,HAVING 是在 GROUP BY 之后应用的,而 WHERE 是在 GROUP BY 之前。
- SELECT现在,数据库会选择要显示的列。这包括任何在 SELECT 语句中明确指定的列,以及任何聚合函数的结果。
- ORDER BY数据库会根据 ORDER BY 子句中的列对结果进行排序。如果未指定 ORDER BY,则结果集的顺序可能是不确定的。
- LIMIT / OFFSET(在某些数据库中)数据库会限制返回的行数,并可能跳过一定数量的行(例如,在分页场景中)。
以下面查询语句为例进行说明:
SELECT select_cloumns FROM table WHERE some_condition GROUP BY group-cloumns HAVING some_aggregate_condition;
那么,其逻辑执行顺序将是:
- 从 table 中选择数据(根据 FROM)。
- 应用 WHERE 条件(some_condition)。
- 根据 group-cloumns列对数据进行分组。
- 计算任何聚合函数(虽然在这个例子中我们没有明确指定)。
- 应用 HAVING 条件(some_aggregate_condition)。
- 选择 select_cloumns列来显示结果。
注意:虽然上述步骤描述了逻辑执行顺序,但实际的物理执行计划可能会因数据库优化器的决策而有所不同。
- 上一篇: 10道有深度的mysql查询语句面试题
- 下一篇: MySQL相关(一)- 一条查询语句是如何执行的
猜你喜欢
- 2024-10-27 MySQL左查询最全介绍(sql 左查询)
- 2024-10-27 mysql查询指定父级下所有子级(mysql根据子节点查父)
- 2024-10-27 MySQL数据库入门(七)多表查询及大量练习
- 2024-10-27 mysql进行数据查询(单表查询)(mysql 查询数据表)
- 2024-10-27 【执行计划】MySQL如何执行查询?(mysql执行查询语句)
- 2024-10-27 MySQL查询列必须和group by字段一致吗?
- 2024-10-27 查看MySQL所有数据库列表(mysql怎么查看数据库列表)
- 2024-10-27 「mysql」mysql调优时必须掌握的慢查询语句排查命令
- 2024-10-27 有一张1000W 数据记录的表,主键id自增,如何随机抽取10条记录?
- 2024-10-27 MySQL进阶实战7,查询的执行过程(mysql查询机制)
- 06-13C++之类和对象(c++中类和对象的区别)
- 06-13C语言进阶教程:数据结构 - 哈希表的基本原理与实现
- 06-13C语言实现见缝插圆游戏!零基础代码思路+源码分享
- 06-13Windows 10下使用编译并使用openCV
- 06-13C语言进阶教程:栈和队列的实现与应用
- 06-13C语言这些常见标准文件该如何使用?很基础也很重要
- 06-13C语言 vs C++:谁才是编程界的“全能王者”?
- 06-13C语言无锁编程指南(c语言锁机代码)
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)