0

0

mysql SQL执行中的查询解析、优化与执行过程

P粉602998670

P粉602998670

发布时间:2026-03-19 12:32:31

|

840人浏览过

|

来源于php中文网

原创

MySQL查询执行流程分四步:解析→预处理→优化→执行;解析做词法语法分析,预处理校验语义(如表存在性),优化器生成执行计划,执行阶段调用存储引擎接口完成物理操作。

mysql sql执行中的查询解析、优化与执行过程

MySQL 查询执行流程分哪几步?

MySQL 执行一条 SELECT 语句,实际会经过「解析 → 预处理 → 优化 → 执行」四个核心阶段,中间不涉及存储引擎的物理读写,但每步都直接影响最终性能和结果正确性。

关键点在于:**解析和预处理由 Server 层完成,优化器决定执行计划,而执行阶段才真正调用存储引擎(如 InnoDB)接口**。这意味着即使 SQL 语法合法、字段存在,也可能在优化或执行时失败。

SQL 解析失败常见原因有哪些?

解析阶段主要做词法分析(Lexical Analysis)和语法分析(Syntax Analysis),不校验表或字段是否存在。

  • SELECT * FROM users WHERE age > ; —— 缺少右操作数,报错 ERROR 1064 (42000)
  • SELECT name, COUNT(*) FROM users; —— name 未出现在 GROUP BY 中且非聚合字段,在 sql_mode=ONLY_FULL_GROUP_BY 下解析通过但预处理失败
  • 使用了 MySQL 8.0 新增的窗口函数(如 ROW_NUMBER())但在 5.7 环境下执行,会直接报 ERROR 1305 (42000): FUNCTION xxx.ROW_NUMBER does not exist,这其实发生在解析后、函数注册检查时

为什么 EXPLAIN 显示的执行计划和实际执行不一致?

EXPLAIN 只模拟优化器生成的「预估计划」,它不触发真实执行,也不考虑运行时参数(如绑定变量值、临时内存限制、并发负载)。真实执行可能因以下原因绕过该计划:

  • 优化器估算行数严重偏差(例如 WHERE created_at > '2020-01-01' 实际匹配 95% 行,但统计信息陈旧,导致选了索引扫描而非全表扫描)
  • JOIN 顺序被运行时重排:当某张表返回结果集极小(如 SELECT ... FROM config WHERE key = 'feature_x'),优化器可能动态调整驱动表
  • 查询中含子查询或 UNIONEXPLAIN 无法反映物化临时表行为;真实执行时可能生成 DERIVEDMATERIALIZED 表,触发磁盘临时表(Using temporary; Using filesort
EXPLAIN FORMAT=TREE SELECT u.name FROM users u JOIN orders o ON u.id = o.user_id WHERE o.status = 'paid';

MySQL 8.0+ 的 FORMAT=TREE 比传统格式更贴近真实执行树,但仍不保证完全一致。

Boba.video
Boba.video

AI动漫视频生成器

下载

执行阶段哪些操作真正由存储引擎承担?

Server 层把优化后的执行计划翻译为「逐行请求」,交由存储引擎完成具体动作。InnoDB 主要响应以下调用:

  • index_read():按索引键定位记录(含主键/二级索引查找)
  • row_search_for_mysql():执行范围扫描、ORDER BY 排序(若索引能覆盖)
  • ha_innobase::write_row() / update_row():DML 操作的具体实现
  • 事务相关:start_stmt()commit()rollback() 最终映射为 InnoDB 的 trx_start_if_not_started_xa() 等内部事务控制

注意:WHERE 条件中的函数(如 YEAR(created_at) = 2023)无法下推到 InnoDB,Server 层必须从引擎拉回所有行再计算——这是索引失效的底层原因。

整个过程里最容易被忽略的是「预处理阶段的语义检查」:它比解析严格,但又比执行轻量。比如 SELECT COUNT(*) FROM non_existent_table 在预处理就报错,而 SELECT * FROM users WHERE id IN (SELECT user_id FROM nonexistent) 要到执行子查询时才暴露问题。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

1135

2023.10.12

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

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

340

2023.10.27

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

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

381

2024.02.23

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

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

2320

2024.03.06

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

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

380

2024.03.06

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

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

1784

2024.04.07

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

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

588

2024.04.29

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

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

441

2024.04.29

bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

22

2026.03.18

热门下载

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

精品课程

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

共48课时 | 2.6万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 861人学习

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

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