01 | 基础架构:一条SQL查询语句是如何执行的?

此系列文章为极客时间课程《MySQL 实战 45 讲》的学习笔记!

引言

在了解 SQL 查询语句如何执行之前,先了解下MySQL 的基本架构示意图。

MySQL 分为 Server 层和引擎层。

  • Server 层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖 MySQL 的大多数核心服务功能,以及所有的内置函数。
  • 存储引擎层负责数据的存储和提取。其架构模式是插件式的,支持 InnoDB、MyISAM、Memory 等多个存储引擎。MySQL5.5.5 版本默认是 InnoDB 引擎。

1.连接器

连接器负责客户端和服务端的连接建立、获取权限、维护和管理连接。

连接建立之后,若没有后续动作,则此连接出于空闲状态,通过show processlist命令查看,Command列为 Sleep 的表示当前连接空闲。

空闲连接超时时间由参数wait_timeout控制,默认是 8 小时

2.查询缓存

MySQL 服务器收到一个查询请求后,会先去缓存查询是否存在,缓存通过 Key-Value 的形式存储,key 为查询的 sql 语句,value 为查询结果。

但是缓存的设计非常鸡肋,因为查询缓存的失效非常频繁,只要有表的数据更新,那么这张表的查询缓存就会失效。

所以建议查询缓存按需使用,可以通过设置参数query_cache_type=DEMAND关闭缓存,当某个 sql 需要使用缓存时,可以显示的指定

sql 复制代码
mysql> select SQL_CACHE * from T where ID=10;

MySQL8中直接删除了缓存功能。

3.分析器(WHAT)

分析器主要做词法分析和语法分析。

  • 词法分析:分析 sql 中的字符串分别代表什么,比如通过 select 可知这是一个查询语句。
  • 语法分析:根据 MySQL 语法规则,判断 sql 是否符合语法。

4.优化器(HOW)

分析器分析 sql 语句是要做什么。优化器是分析 sql 如何做。

比如 sql 的执行有多种方案,优化器需要选择一种最优效率的执行方案,

5.执行器(DO)

接下来就进入的正式执行阶段。

  • 首先判断当前用户是否有表的执行权限。
  • 调用执行引擎的接口,查询数据,没查询一条判断是否满足条件,一直到表中最后一条数据。
  • 然后执行器将满足条件的数据返回给客户端。
相关推荐
YuTaoShao1 小时前
Java八股文——Spring「Spring 篇」
java·数据库·spring
新知图书2 小时前
扣子数据库实战案例:搭建AI登记助手
数据库·智能体·扣子
在未来等你2 小时前
SQL进阶之旅 Day 28:跨库操作与ETL技术
sql·mysql·postgresql·etl·cross-database·data-integration·database-optimization
麦兜*3 小时前
【Mysql及各种关系型数据库全面对比与深度解析(2025版)】
数据库·sql·mysql·postgresql·oracle·sqlserver·mariadb
扶光与望舒呀3 小时前
mysql 的卸载- Windows 版
数据库·mysql
星垣矩阵架构师3 小时前
架构设计之存储高性能——非关系型数据库(NoSQL)
数据库·架构·nosql
明月看潮生3 小时前
青少年编程与数学 01-011 系统软件简介 16 Redis数据库
数据库·redis·青少年编程·编程与数学
明月看潮生3 小时前
青少年编程与数学 01-011 系统软件简介 15 MongoDB数据库
数据库·mongodb·青少年编程·编程与数学
喵叔哟4 小时前
第7章:Neo4j索引与约束
数据库·oracle·neo4j
Winn~4 小时前
MySQL行锁、记录锁、间隙锁、临建锁、意向锁、表锁
数据库·mysql