MySQL innodb中一条sql的执行流程

devtools/2025/1/15 3:21:02/

MySQL InnoDB 存储引擎中,执行一条 SQL 语句的流程涉及多个模块的协作。下面是一个详细的讲解,包括 SQL 查询从接收、解析、优化、执行到结果返回的完整过程。


1. SQL 的执行流程概述

一条 SQL 的执行流程可以分为以下几个主要阶段:

  1. 客户端连接管理
  2. SQL 接收与解析
  3. 查询优化
  4. 执行计划生成
  5. 存储引擎层交互
  6. 返回结果

1. 客户端连接管理

  • 连接建立
    • 客户端通过协议(如 TCP/IP 或本地套接字)连接到 MySQL 服务器。
    • MySQL 服务器通过连接管理模块分配线程来处理该客户端的请求。
  • 权限验证
    • MySQL 检查用户身份和权限,确保该用户有权限执行该 SQL。
    • 如果验证失败,则直接返回错误。

2. SQL 接收与解析

  1. 接收 SQL

    • 客户端发送 SQL 查询,MySQL 接收后将其传递到查询处理模块。
  2. 解析器(Parser)

    • SQL 文本被解析为 抽象语法树(AST)
    • 检查 SQL 语法是否正确。如果语法错误,返回错误信息。
  3. 预处理(Preprocessor)

    • 校验语义,例如:
      • 检查表是否存在。
      • 检查字段名是否正确。
      • 验证用户对表和字段的权限。

3. 查询优化

MySQL 使用查询优化器生成高效的执行计划。

  1. 查询重写

    • 将查询转化为更高效的等价形式,例如:
      • SELECT * FROM employees WHERE age > 25 可能改写为索引查询。
      • 子查询可能被优化为 JOIN。
  2. 生成候选执行计划

    • 优化器根据查询语句的特性和表的结构生成多个候选执行计划。
  3. 选择最优计划

    • MySQL 使用 成本模型(Cost Model) 评估每个执行计划的代价(如扫描行数、索引使用情况)。
    • 选择代价最低的执行计划。

工具提示:可以通过 EXPLAIN 查看优化器选择的执行计划。


4. 执行计划生成

优化器确定了执行计划后,会将其交给执行器。

  • 执行器是 MySQL 的核心模块之一,负责根据执行计划逐步执行 SQL。

5. 存储引擎层交互

InnoDB 作为 MySQL 的存储引擎,负责管理表数据的存储和读取。

5.1 执行器与存储引擎的协作
  • 读取数据
    • 执行器根据执行计划向存储引擎发送请求,例如:
      • 使用主键或索引读取记录。
      • 全表扫描。
  • 过滤条件
    • 如果查询条件未完全由索引覆盖,执行器会从存储引擎读取数据后再进行过滤。
5.2 InnoDB 内部的处理流程
  1. 索引管理

    • InnoDB 使用 B+树 索引定位记录。
    • 如果是索引覆盖查询(索引中包含所有所需列),直接返回索引数据。
    • 如果需要完整记录(非索引列),通过主键回表获取。
  2. Buffer Pool 缓存

    • InnoDB 首先在 Buffer Pool 中查找所需页(数据页或索引页)。
    • 如果找到(命中),直接从内存返回。
    • 如果未命中,从磁盘加载到 Buffer Pool 中。
  3. 事务管理

    • InnoDB 根据事务隔离级别(如 RRRC)处理多事务并发。
    • 通过 MVCC锁机制 保证数据一致性。
  4. 日志记录

    • Redo Log:记录数据更改,用于崩溃恢复。
    • Undo Log:记录数据的旧版本,用于事务回滚和 MVCC 实现。
5.3 返回结果
  • InnoDB 将查询结果返回给执行器,执行器再交由 MySQL 服务层。

6. 返回结果

  1. 数据返回

    • MySQL 将结果集封装成客户端协议格式。
    • 返回给客户端。
  2. 清理工作

    • MySQL 清理执行过程中分配的临时资源(如内存、临时表)。

2. 流程示意图

以下是 SQL 流程的简化示意:

 

sql

复制代码

客户端发送 SQL ↓ 连接管理与权限校验 ↓ SQL 解析 ↓ 查询优化器 ↓ 执行器 ↓ 存储引擎(InnoDB) ↓ 事务控制(MVCC/锁) ↓ 数据存取(Buffer Pool/B+树) ↓ 日志管理(Redo/Undo) ↓ 执行器接收数据 ↓ 结果返回客户端


3. 示例:执行一条 SQL

假设有如下 SQL 查询:

 

sql

复制代码

SELECT name, department_name FROM employees e JOIN departments d ON e.department_id = d.id WHERE e.age > 30;

执行流程:

  1. 解析器

    • 解析 SQL,验证 employeesdepartments 表是否存在。
    • 验证字段 namedepartment_name 是否有效。
    • 验证用户权限。
  2. 查询优化器

    • 识别 JOIN,选择执行顺序。
    • 判断是否使用 employees.department_iddepartments.id 索引。
    • 生成执行计划。
  3. 执行器

    • 逐行扫描 employees 表,通过 department_id 查找 departments 表的 id
    • 过滤 age > 30 条件。
  4. 存储引擎(InnoDB)

    • 使用索引(如 B+树)访问 employeesdepartments 数据。
    • 利用 Buffer Pool 提高访问速度。
    • 记录日志,处理事务。
  5. 返回结果

    • 执行器整合结果,返回给客户端。

4. 总结

MySQL InnoDB 中 SQL 的执行流程核心在于 层次化的处理机制

  • 服务层负责解析、优化、权限管理。
  • 存储引擎层负责数据存储、索引查找、事务控制等。

通过 EXPLAIN 分析执行计划,可以了解 SQL 在各阶段的执行细节,并针对性能问题进行优化。


http://www.ppmy.cn/devtools/150567.html

相关文章

网络安全:守护数字世界的防线

在信息化时代,网络已成为人们生活和工作的基础设施,从在线购物、社交互动到企业运营、政府服务,无处不在的网络连接着全球各地的人们和组织。然而,网络的便捷性也带来了诸多安全风险,网络安全问题日益凸显,…

【广西乡镇界】arcgis格式shp数据乡镇名称和编码2020年内容测评

【广西乡镇界】arcgis格式shp数据乡镇名称和编码2020年内容测评

Springcloudgateway 请求无响应,要怎么处理

当遇到Spring Cloud Gateway请求无响应的问题时,可能的原因和解决方案包括以下几个方面: 一、可能的原因 服务端负载过高: 当服务端处理请求的能力不足,导致无法及时响应请求时,可能会出现无响应的情况。 服务端资…

【Uniapp-Vue3】@import导入css样式及scss变量用法与static目录

一、import导入css样式 在项目文件中创建一个common文件夹,下面创建一个css文件夹,里面放上style.css文件,编写的是公共样式,我们现在要在App.vue中引入该样式。 在App.vue中引入该样式,这样就会使样式全局生效&#…

Git学习记录

针对各个项目的gitignore文件示例 github/gitignore: A collection of useful .gitignore templates 忽略文件 文件 .gitignore 的格式规范如下: • 所有空行或者以 # 开头的行都会被 Git 忽略。 • 可以使用标准的 glob 模式匹配。 • 匹配模式…

java项目启动时,执行某方法

1. J2EE项目 在Servlet类中重写init()方法,这个方法会在Servlet实例化时调用,即项目启动时调用。 import javax.servlet.ServletException; import javax.servlet.http.HttpServlet;public class MyServlet extends HttpServlet {Overridepublic void …

window.print()预览时表格显示不全

问题描述:使用element的table组件,表格列宽为自适应,但使用window.print()方法预览的页面会直接按预览宽度截取表格内容进行展示,造成表格可能的显示不全问题 解决方法:添加如下样式 media print {::v-deep {// 表头…

CSS语言的数据类型

CSS语言的数据类型详解 引言 CSS(层叠样式表)是一种用来描述HTML文档外观的样式表语言。尽管CSS主要用于视觉呈现,而不是数据处理,但它仍然包含了一定的数据类型,这些数据类型是决定样式和布局的重要因素。掌握这些数…