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)

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

  • 首先判断当前用户是否有表的执行权限。
  • 调用执行引擎的接口,查询数据,没查询一条判断是否满足条件,一直到表中最后一条数据。
  • 然后执行器将满足条件的数据返回给客户端。
相关推荐
vvilkim34 分钟前
SQL语言基础:从入门到掌握结构化查询语言
数据库·sql·oracle
Navicat中国1 小时前
Navicat BI 数据分析功能上线 | 数据洞察新方法
数据库·人工智能·信息可视化·数据挖掘·数据分析·navicat·bi
八股文领域大手子2 小时前
Spring Boot Controller 如何处理HTTP请求体
java·开发语言·sql·spring·spring cloud
AI大模型顾潇2 小时前
[特殊字符] Milvus + LLM大模型:打造智能电影知识库系统
数据库·人工智能·机器学习·大模型·llm·llama·milvus
阿里云云原生2 小时前
阿里云 SLS 多云日志接入最佳实践:链路、成本与高可用性优化
数据库·阿里云·云计算
kaixiang3003 小时前
sqli-labs靶场18-22关(http头)
数据库
Pasregret3 小时前
MySQL 安全架构:从渗透测试到合规审计
数据库·mysql·安全架构
数巨小码人3 小时前
PostgreSQL冻结过程
数据库·postgresql
阿文弟4 小时前
MYSQL之索引结构,为何要用B+树
数据库·mysql