0

0

SQL执行顺序深度解析_SQL SELECT执行流程说明

冷漠man

冷漠man

发布时间:2025-12-05 22:05:02

|

284人浏览过

|

来源于php中文网

原创

SQL执行顺序为FROM→WHERE→GROUP BY→HAVING→SELECT→DISTINCT→ORDER BY→LIMIT,而非书写顺序;FROM最先加载数据源,WHERE过滤原始行,GROUP BY分组后HAVING筛选分组结果,SELECT才计算表达式和别名,最后ORDER BY排序、LIMIT截断。

sql执行顺序深度解析_sql select执行流程说明

SQL的SELECT语句看似简单,实际执行时并非按书写顺序运行。理解其真实执行顺序,是写出高效、正确查询的基础,也能帮你避开常见陷阱,比如WHERE中引用了SELECT里定义的别名、或GROUP BY和聚合函数配合出错等问题。

FROM:最先执行,确定数据源

无论你写多少表、用什么JOIN,数据库第一步永远是从FROM子句开始——加载基础表或视图,生成初始的笛卡尔积(如果有多表且没ON条件)。如果有子查询或CTE(WITH),也会在此阶段完成物化或展开。

  • 多表JOIN时,优化器可能重排表顺序,但逻辑上仍以FROM列出的表为起点
  • 如果FROM中包含复杂的子查询,它会先执行完,结果作为临时“虚表”供后续步骤使用
  • 注意:WHERE、GROUP BY等都不能影响FROM阶段的表加载,哪怕WHERE条件再严格,全表扫描仍可能在FROM阶段发生

WHERE → GROUP BY → HAVING:筛选与分组三步连动

在FROM产出初始行集后,数据库立即应用WHERE过滤——这是第一个真正“减少数据量”的环节。接着按GROUP BY分组,再用HAVING对分组结果做二次筛选。这三者构成一个紧密的“分组前/后筛选链”。

FreeTTS
FreeTTS

FreeTTS是一个免费开源的在线文本到语音生成解决方案,可以将文本转换成MP3,

下载
  • WHERE作用于原始行,不能用聚合函数(如SUM、COUNT)或SELECT中的列别名
  • GROUP BY必须包含SELECT中所有非聚合列(严格模式下),否则报错
  • HAVING可引用聚合函数和GROUP BY字段,但不能引用WHERE未出现的非分组列

SELECT → DISTINCT → ORDER BY → LIMIT:最终呈现层

直到这时,SELECT才真正执行——计算表达式、取别名、去重(DISTINCT)、排序(ORDER BY)、截断(LIMIT/OFFSET)。这个阶段的数据已不可被WHERE或HAVING修改。

  • SELECT中定义的别名,在WHERE、GROUP BY、HAVING中都不可用(因为它们早已执行完毕)
  • ORDER BY可以引用SELECT中的别名或位置序号(如ORDER BY 1),但标准SQL更推荐用别名
  • LIMIT不是SQL标准语法(MySQL/PostgreSQL支持,SQL Server用TOP,Oracle用ROWNUM或FETCH FIRST),但它总在最后生效,不改变逻辑结果集大小,只控制返回行数

基本上就这些。记住:写的时候从SELECT开始顺手敲,跑的时候从FROM开始层层推进。搞清这个顺序,很多“为什么报错”“为什么结果不对”的问题就迎刃而解了。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

685

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

323

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1117

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

359

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

717

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

577

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

419

2024.04.29

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

6

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 12.9万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

Go语言教程-全程干货无废话
Go语言教程-全程干货无废话

共100课时 | 9.8万人学习

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

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