当执行如下 SQL:

SELECT * FROM users WHERE id = 1;

在数据库内部,其实会经历多个复杂且有序的阶段。以下是 MySQL(InnoDB 引擎)中 SQL 查询语句从发送到结果返回的完整执行流程。


客户端连接阶段

  • 客户端(如 JDBC、MySQL Shell)通过 TCP 与 MySQL 服务器建立连接。
  • 连接器模块完成身份认证(用户名/密码)、权限校验。
  • 若使用连接池,连接可能已被复用。

语法分析阶段(Parser)

1. 词法分析(Lexical Analysis)

  • 将 SQL 字符串拆解成关键字、标识符、操作符等 Token。
  • 例子:SELECT, *, FROM, users, WHERE, id, =, 1

2. 语法分析(Syntax Analysis)

  • 依据 SQL 语法规则生成抽象语法树(AST)
  • 若语法不合法,此阶段抛出语法错误。

预处理阶段(Preprocessor)

  • 验证表/字段是否存在。
  • 检查当前用户是否有访问权限。
  • 解析字段别名、函数等表达式。
  • 确定查询涉及的表和列。
  • 最终输出逻辑查询结构

查询优化阶段(Optimizer)

优化器根据预处理阶段的语义结构生成最优执行计划(Execution Plan)

1. 访问路径选择

  • 使用 索引扫描 还是 全表扫描
  • 是否走覆盖索引,是否需要回表?

2. 连接顺序优化(Join Order)

  • 对多表 JOIN,决定访问顺序与连接方法(如 Nested Loop、Hash Join)。

3. 成本估算(Cost Estimation)

  • 评估每种执行方式的代价(IO 次数、内存使用等)。
  • 选择代价最小的执行路径。

查询执行阶段(Executor)

执行器根据优化器生成的执行计划与存储引擎交互,完成数据访问。

执行器主要职责:

  • 调用引擎接口访问表和索引。
  • 进行 WHERE 过滤、JOIN、聚合、排序、分组等操作。
  • 构造并返回最终结果集。

存储引擎访问阶段(以 InnoDB 为例)

MySQL 使用插件式存储引擎架构。以 InnoDB 为例:

  • 数据页首先尝试从 Buffer Pool(缓冲池)中读取。
  • 若不在缓冲池,则从磁盘读取并加入缓冲池。
  • 使用 B+ 树索引定位记录。
  • 如果为覆盖索引(索引包含查询列),可避免回表。
  • 对于非索引字段,需根据主键“回表”查找。

结果返回阶段

  • 执行器生成的结果集通过 MySQL 协议格式化。
  • 数据从服务器通过网络传输返回给客户端。
  • 客户端解析并展示结果。

日志与事务支持(InnoDB)

虽然 SELECT 查询本身不会写入日志,但其他 SQL 会涉及以下机制:

  • Undo Log:支持事务回滚、MVCC。
  • Redo Log:保证事务持久化(WAL机制)。
  • Binlog:记录变更操作,用于主从复制和恢复。

注:查询语句可能间接使用 undo log(如 MVCC)。


SQL 执行流程图

Client Connector Parser Preprocessor Optimizer Executor StorageEngine 提交 SQL 查询 权限校验、连接管理 语法分析、语义分析 检查字段/表、构造逻辑查询块 生成并下发最优执行计划 根据执行计划读取数据(可能命中索引) 返回数据页或记录 返回结果集 Client Connector Parser Preprocessor Optimizer Executor StorageEngine

使用 EXPLAIN 查看执行计划

EXPLAIN SELECT * FROM users WHERE id = 1;

查看字段含义:

  • id: 查询标识
  • select_type: 查询类型(SIMPLE/PRIMARY等)
  • table: 访问的表
  • type: 连接类型(ALL、index、range、ref、const 等)
  • key: 使用的索引
  • rows: 扫描的行数
  • Extra: 是否使用临时表、排序、是否回表等信息

查询性能影响因素

影响因素说明
是否走索引非索引字段将触发全表扫描
是否回表二级索引查询非索引字段时需根据主键回表
连接数与并发并发高时,CPU/IO/锁资源紧张
查询缓存MySQL 8.0 起已废弃
临时表与排序ORDER BY / GROUP BY 可能触发文件排序与临时表
网络延迟大结果集网络传输慢

总结

一条 SQL 查询的完整内部执行流程如下:

  1. 客户端连接 → 建立连接并认证
  2. 解析 SQL → 词法/语法分析生成语法树
  3. 预处理 → 验证权限与对象合法性
  4. 优化器选择最优执行计划
  5. 执行器执行 SQL 逻辑
  6. 存储引擎读取数据
  7. 返回结果集给客户端

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/89973.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/89973.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/89973.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

超详细yolo8/11-detect目标检测全流程概述:配置环境、数据标注、训练、验证/预测、onnx部署(c++/python)详解

文章目录 一、配置环境二、数据标注三、模型训练四、验证预测五、onnx部署c 版python版本 一、配置环境 我的都是在Linux系统下,训练部署的;模型训练之前,需要配置好环境,Anaconda、显卡驱动、cuda、cudnn、pytorch等&#xff1b…

阿里云Flink:开启大数据实时处理新时代

走进阿里云 Flink 在大数据处理的广袤领域中,阿里云 Flink 犹如一颗璀璨的明星,占据着举足轻重的地位。随着数据量呈指数级增长,企业对数据处理的实时性、高效性和准确性提出了前所未有的挑战 。传统的数据处理方式逐渐难以满足这些严苛的需…

【Linux】基础开发工具(1)

1. 软件包管理器 1.1 什么是软件包 在Linux下安装软件, ⼀个常用的办法是下载到程序的源代码, 并进行编译, 得到可执行程序. 但是这样太麻烦了, 于是有些人把⼀些常⽤的软件提前编译好, 做成软件包(可以理解成windows上 的安装程序)放在⼀个服务器上, 通过包管理器可以很⽅便…

蓝桥杯51单片机设计

#超声波原理# ①超声波测距原理:声波反射原理 声波分类: 超声波测距原理 超声波频率越高,波长越短,反身性越强,衍射性越弱 ②超声波模块原理 发射原理 跳线帽 接收原理 问题: 1.超声波发射模块需…

【LeetCode 热题 100】240. 搜索二维矩阵 II——排除法

Problem: 240. 搜索二维矩阵 II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性: 每行的元素从左到右升序排列。 每列的元素从上到下升序排列。 文章目录 整体思路完整代码时空复杂度时间复杂度:O(M N)空间复…

Android Input 系列专题【inputflinger事件的读取与分发】

Android输入系统在native中的核心工作就是,从Linux驱动设备节点中读取事件,然后将这个事件进行分发,这两项工作分别交给了InputReader和InputDispatcher来做。 他们的源码都属于native层inputflinger里面的一部分,如下架构&#…

【大模型LLM】GPU计算效率评估指标与优化方法:吞吐率

GPU计算效率评估指标与优化方法:吞吐率 一、核心效率指标二、大模型吞吐率(Large Model Throughput)三、关键性能瓶颈分析四、实际测量工具五、优化策略总结 一、核心效率指标 吞吐率(Throughput) 定义:单位…

Nestjs框架: 集成 Prisma

概述 在 NestJS 的官方文档中,有两处对数据库进行了介绍 第一处位于左侧“Techniques(技术)”部分下的“数据库”板块,中文文档里同样有这个位置。 Database 第二处是下面的“Recipes (秘籍)”板块,这里有多个部分都与…

CppCon 2018 学习:What Do We Mean When We Say Nothing At All?

提供的内容深入探讨了C编程中的一些关键概念,特别是如何编写清晰、易维护的代码,并展示了一些C17的新特性。我将对这些内容做中文的解释和总结。 1. 良好的代码设计原则 什么是“良好的代码”? 能工作:代码实现了预期功能。能在…

C语言中的输入输出函数:构建程序交互的基石

在C语言的世界里,输入输出(I/O)操作是程序与用户或外部数据源进行交互的基本方式。无论是从键盘接收用户输入,还是将处理结果显示到屏幕上,亦或是读写文件,都离不开C语言提供的输入输出函数。本文将深入探讨…

高速信号眼图

横轴体系时域的抖动大小;纵轴体现电压的噪声。 噪声越大,眼高越小。 抖动越大,眼宽越窄。 眼图的模板是定义好的最大jitter和噪声的模板范围。就是信号的不可触碰区域。信号波形不能够触碰到模板或者进行模板中。也就是眼图中的线轨迹要在眼…

VisualSVN Server 禁止的特殊符号 导致的。具体分析如下:错误提示解读

是由于 文件夹名称中包含了 VisualSVN Server 禁止的特殊符号 导致的。具体分析如下&#xff1a; 错误提示解读 错误信息明确说明&#xff1a; Folder name cannot contain following symbols < > : " / | and start or end by period. 即 文件夹名称不能包含以下…

再见,WebSecurityConfigurerAdapter!你好,SecurityFilterChain

对于许多经验丰富的 Spring开发者来说&#xff0c;WebSecurityConfigurerAdapter 是一个再熟悉不过的名字。在很长一段时间里&#xff0c;它几乎是所有 Spring Security 配置的起点和核心。然而&#xff0c;随着 Spring Boot 3.x 和 Spring Security 6.x 的普及&#xff0c;这个…

web前端面试-- MVC、MVP、MVVM 架构模式对比

MVC、MVP、MVVM 架构模式对比 基本概念 这三种都是用于分离用户界面(UI)与业务逻辑的架构模式&#xff0c;旨在提高代码的可维护性、可测试性和可扩展性。 1. MVC (Model-View-Controller) 核心结构&#xff1a; Model&#xff1a;数据模型和业务逻辑View&#xff1a;用户界面展…

【C#】MVVM知识点汇总-2

在C#中实现MVVM&#xff08;Model-View-ViewModel&#xff09;架构时&#xff0c;可以总结以下几个关键知识点&#xff0c;并通过具体的代码示例来进行说明。 1. 模型 (Model) 模型包含应用程序中的数据和业务逻辑。通常与数据库交互。 public class User { public int Id {…

一文了解PMI、CSPM、软考、、IPMA、PeopleCert和华为项目管理认证

1 引言 常见的项目管理方面的认证有PMI、IPMA、PeopleCert、CSPM、软考和华为项目管理认证6个认证。本篇文章让你一文了解各认证的基本主要内容。 2 核心定位 目前全球范围内最具影响力的六大认证体系各有特色&#xff0c;源于不同的管理哲学和实践背景。六大认证体系的核心…

bean注入的过程中,Property of ‘java.util.ArrayList‘ type cannot be injected by ‘List‘

一、问题 在spring实践bean注入ArrayList属性的时候报错&#xff1a;Property of ‘java.util.ArrayList’ type cannot be injected by ‘List’二、原因分析 在尝试将 Spring 配置中的 注入到一个 ArrayList 类型的属性时出现了类型不匹配问题。核心问题在于&#xff1a;Spr…

自注意力机制原理: 向量矩阵案例进行说明

自注意力机制原理: 向量矩阵案例进行说明 目录 自注意力机制原理: 向量矩阵案例进行说明一个单词和所有单词进行乘法运算,提取特征一、场景设定:翻译句子“我喜欢深度学习”二、向量矩阵构建:以“我”为例计算自注意力三、矩阵视角:批量计算整个序列的自注意力四、向量矩…

D3 面试题100道之(61-80)

这里是D3的面试题,我们从第 61~80题 开始逐条解答。一共100道,陆续发布中。 🟨 面试题(第 61~80 题) 61. D3 中如何绘制饼图? 使用 d3.pie() 生成角度数据,再结合 d3.arc() 创建路径。 示例: const data = [10, 20, 30

flutter更改第三方库pub get的缓存目录;更改.gradle文件夹存放目录

1.在目标目录中新建文件夹flutter_pub_cache 2.在“用户变量“或“系统变量”中点击“新建” 变量名: PUB_CACHE 变量值: D:\flutter_pub_cache 3.打开新的终端运行或者从Android studio 控制台运行&#xff1a;flutter pub cache repair或者flutter pub clean pub读取新的变…