MySQL查询执行顺序为:FROM→WHERE→GROUP BY→HAVING→SELECT→ORDER BY→LIMIT,实际流程包括连接、解析、优化、执行和返回结果,理解该流程有助于优化SQL性能。

MySQL 查询的执行顺序不是按照 SQL 语句书写的顺序来执行的,而是有一套内部的执行流程。理解这个流程有助于优化查询和排查问题。
1. 客户端发送请求
当你在客户端(如命令行、程序)执行一条 SQL 查询时,比如:
SELECT name, age FROM users WHERE age > 25;
这条语句会被发送到 MySQL 服务器,开始进入查询执行流程。
2. 连接器(Connection Handler)
MySQL 先通过连接器验证你的身份(用户名、密码),检查权限。如果认证通过,系统会获取你的权限信息并保持连接。
3. 查询缓存(Query Cache,8.0 已移除)
MySQL 会检查是否已经执行过相同的 SQL 语句(完全一样)。如果命中缓存,直接返回结果,跳过后续步骤。但注意:MySQL 8.0 开始已删除查询缓存功能。
4. 解析器(Parser)
SQL 语句被解析成内部结构。这一步做语法检查,比如关键词拼写、语句结构是否合法。如果写成 SELEC * FROM users;,就会在这里报错。
5. 预处理器(Preprocessor)
检查表名、字段名是否存在,是否有访问权限。例如你查了一个不存在的列,会在这阶段报错。
6. 查询优化器(Optimizer)
这是关键一步。优化器决定如何最高效地执行查询。它会考虑:
- 使用哪个索引(如果有多个)
- 表的连接顺序(多表 JOIN 时)
- 是否走全表扫描还是索引查找
优化器生成一个“执行计划”,可以通过 EXPLAIN SELECT ... 查看。
7. 执行器(Executor)
根据优化器生成的执行计划,调用存储引擎的接口执行操作。执行过程大致如下:
- 打开表,检查用户是否有读权限
- 调用存储引擎(如 InnoDB)逐行读取或通过索引查找数据
- 对每行判断是否满足 WHERE 条件(比如 age > 25)
- 取出符合条件的字段(name, age)
- 处理 ORDER BY、GROUP BY、LIMIT 等操作
8. 存储引擎层(如 InnoDB)
真正负责数据的读写。InnoDB 会从磁盘或内存缓冲池(Buffer Pool)中加载数据页,按需返回给执行器。
9. 返回结果
执行器将最终结果集返回给客户端。如果是 SELECT,你会看到数据;如果是 UPDATE,会返回影响行数。
关于 SELECT 的书写顺序 vs 执行顺序
我们写的 SQL 通常是:
SELECT → FROM → WHERE → GROUP BY → HAVING → ORDER BY → LIMIT
但实际执行顺序是:
- FROM:先确定数据来源(哪张表,是否 JOIN)
- WHERE:过滤行,筛选出符合条件的数据
- GROUP BY:对数据分组
- HAVING:对分组后的结果再过滤
- SELECT:选择要返回的字段
- ORDER BY:排序
- LIMIT:限制返回行数
所以你在 WHERE 中不能使用 SELECT 中定义的别名,因为那时别名还没生成。
小结
MySQL 查询执行流程本质是:连接 → 解析 → 优化 → 执行 → 返回结果。理解这个流程,能帮助你明白为什么某些查询慢、索引为什么不生效、以及如何写出更高效的 SQL。
基本上就这些。










