一个SQL的执行过程详解

互联网架构师

共 3490字,需浏览 7分钟

 ·

2021-12-31 14:36

上一篇:厌倦 VMware,试试更轻量级的虚拟机!
作者:猿来是八阿哥
链接:https://www.jianshu.com/p/e2926d6a808f


一个sql的执行过程

一、 组成部分

PDO_MYSQL is a driver that implements the PHP Data Objects (PDO) interface to enable access from PHP to MySQL databases.

二、 大概流程

  • MySQL server 层的 连接器 对来自客户端的连接进行验证,包含:
  • MySQL server 层的 查询缓存 对客户源原始SQL进行 缓存命中检测:命中则直接返回,未命中则进一步执行查询。
  • MySQL server 层的 解析器 对查询语句进行解析,得到查询语句的 解析树

  • MySQL server 层的 预处理器 对 解析树 进一步验证。

  • MySQL server 层的 优化器 将 解析树 转化为 执行计划

  • MySQL server 层的 执行器 通过 API 与底层的 存储引擎 进行交互,执行 执行计划

  • MySQL 存储引擎 层得到执行结果,返回给 MySQL server 层。MySQL server 层将结果交由 查询缓存 进行缓存,并返回给客户端

三、 查询缓存

四、 `解析器` 和 `预处理器`

解析器 和 预处理器 的工作主要包含:

五、 优化器

六、 存储引擎

具体的 执行计划 如何执行,依赖于各种不同的 存储引擎 的索引算法,如:

在此不再赘述,可转阅:MySQL之 B-Tree / B+Tree 索引

七、 结果返回客户端

MySQL将结果集返回给客户端是一个 增量、逐步返回 的过程。即:在查询生成第一条结果时,MySQL就可以开始向客户端逐步返回结果集了。


感谢您的阅读,也欢迎您发表关于这篇文章的任何建议,关注我,技术不迷茫!小编到你上高速。
    · END ·
最后,关注公众号互联网架构师,在后台回复:2T,可以获取我整理的 Java 系列面试题和答案,非常齐全


正文结束


推荐阅读 ↓↓↓

1.心态崩了!税前2万4,到手1万4,年终奖扣税方式1月1日起施行~

2.深圳一普通中学老师工资单曝光,秒杀程序员,网友:敢问是哪个学校毕业的?

3.从零开始搭建创业公司后台技术栈

4.程序员一般可以从什么平台接私活?

5.清华大学:2021 元宇宙研究报告!

6.为什么国内 996 干不过国外的 955呢?

7.这封“领导痛批95后下属”的邮件,句句扎心!

8.15张图看懂瞎忙和高效的区别!

浏览 10
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报