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)

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

  • 首先判断当前用户是否有表的执行权限。
  • 调用执行引擎的接口,查询数据,没查询一条判断是否满足条件,一直到表中最后一条数据。
  • 然后执行器将满足条件的数据返回给客户端。
相关推荐
小陈phd19 分钟前
混合知识库搭建:本地Docker部署Neo4j图数据库与Milvus向量库
数据库·docker·neo4j
2401_8384725127 分钟前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
知识即是力量ol1 小时前
基于 Redis 实现白名单,黑名单机制详解及应用场景
数据库·redis·缓存
zhihuaba1 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
u0109272711 小时前
Python Web爬虫入门:使用Requests和BeautifulSoup
jvm·数据库·python
小光学长1 小时前
基于ssm的农业管理系统8y15w544(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
Mr_Xuhhh1 小时前
MySQL表的增删改查(CRUD)操作详解
数据库·windows
定偶2 小时前
MySQL安装
数据库·mysql
Zzzzmo_2 小时前
【MySQL】数据库约束 及 表的设计
数据库·mysql
码云数智-大飞2 小时前
Oracle RAS:AI时代守护企业数据安全的智能盾牌
数据库·人工智能·oracle