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

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

引言

在了解 SQL 查询语句如何执行之前,先了解下MySQL 的基本架构示意图。
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 需要使用缓存时,可以显示的指定

mysql> select SQL_CACHE * from T where ID=10

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

3.分析器(WHAT)

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

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

4.优化器(HOW)

分析器分析 sql 语句是要做什么。优化器是分析 sql 如何做。
比如 sql 的执行有多种方案,优化器需要选择一种最优效率的执行方案,

5.执行器(DO)

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

  • 首先判断当前用户是否有表的执行权限。
  • 调用执行引擎的接口,查询数据,没查询一条判断是否满足条件,一直到表中最后一条数据。
  • 然后执行器将满足条件的数据返回给客户端。

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-10 05:02:04       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-10 05:02:04       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-10 05:02:04       58 阅读
  4. Python语言-面向对象

    2024-07-10 05:02:04       69 阅读

热门阅读

  1. Python程序打包成EXE文件指南

    2024-07-10 05:02:04       25 阅读
  2. MongoDB 全文检索

    2024-07-10 05:02:04       23 阅读
  3. threejs

    2024-07-10 05:02:04       24 阅读
  4. python 进阶教程--PIL图像处理

    2024-07-10 05:02:04       26 阅读
  5. CSS 图标:简化设计,优化用户体验

    2024-07-10 05:02:04       29 阅读
  6. C# 中使用模式匹配 备忘

    2024-07-10 05:02:04       26 阅读
  7. 【selenium】元素等待

    2024-07-10 05:02:04       21 阅读
  8. HTMLtable表转C#DataTable

    2024-07-10 05:02:04       33 阅读
  9. WPF设置全局样式

    2024-07-10 05:02:04       26 阅读
  10. AJAX学习笔记上(学习自用)

    2024-07-10 05:02:04       30 阅读