面试速记|图解MySQL执行一条SQL的过程

▲ 点击上方"网管叨bi叨"关注公众号

新开一个系列,尝试把一些常见的面试题做成速记图,用来面试前临时抱佛脚。

最近我这个中年老登也在面试,形式所迫也是没办法。面试中除了问项目经验和管理经验外还经常会被问一些“八股”,说来惭愧,已经快六年没面过试了,很多以前倒背如流的东西,现在也很难想起来。

这情况就跟高中生高考完以为大学稳了,疯玩一暑假后发现自己没录取上要复读的感受差不多。

废话不多说,今天速记指南是:MySQL执行一条SQL语句的过程,这个相信大部分人准备面试的时候都背过,可以再来一起边听歌边快速浏览复习一下。

MySQL的基础架构

想知道SQL语句在MySQL中的执行过程,得先了解一下MySQL的基础架构,它的架构细节看下面这张图。0be8d5e9af68bc5fdc93fa33d83b6df2.pngMySQL 的架构分为:Server 层和 存储引擎层,他们各自的构成为 

Server层:

  • 连接器

  • 查询缓存

  • 分析器

  • 优化器

  • 执行器

存储引擎层:

  • 各个存储引擎,实现存储引擎层定义的统一接口,为Server层提供统一的调用方式

  • 常见的存储引擎如上图

这么多组件,每个都有它们单独的作用,我把他们都整理到了下面这张图里。012f52f830ef20f3ffbc219c2b4e5784.pngServer层:

  • 连接器:验证身份,管理连接

  • 查询缓存:暂存结果集,再次查询直接返回,v8.0 后不再使用查询缓存

  • 分析器:

    • 词法分析,让MySQL知道要干什么 SELECT,还是UPDATE

    • 语法分析,检查SQL语法错误

  • 优化器:决定要用索引,连表查询决定关联顺序

  • 执行器:确定对表有操作权限,调用表使用的存储引擎获取结构

MySQL基础架构有了初步了解后,我们来看SQL的执行过程,先来看查询SQL在MySQL中的执行过程

执行查询SQL的过程

一条查询SQL在MySQL中的执行过程,我都整理到下面这张图了506e77d06b567d16f5f9fc049c10cfdf.png

  • 客户端:发起查询,SELECT * FROM T1 WHERE id = 10

  • 连接器:

    • 验证用户: mysql -h port

    • 验证失败: Access denied for user

    • 验证成功: 查出用户的权限继续执行

  • 连接完成: 处于 idle, show processlist 可查

  • 查询缓存:命中率很低,v8.0 后被取消

  • 分析器:

    • 词法分析: select -> 操作类型 T1 - 操作的表

    • 语法分析: 检查语法错误,出现错误: ERROR 1064 (42000): You have an error in your SQL syntax

  • 优化器:决定怎么查,使用哪个索引,多表join时, join的先后顺序

  • 执行器:

    • 确认有执行权限后 查看 T1 的存储引擎

    • 遍历调用引擎接口 “满足条件的下一行”,确定结果id = 10 后返回, 如果查询无索引,遍历调用引擎接口“下一行"确认结果id=10后返回。

执行更新SQL的过程

接下来是更新SQL在MySQL中的执行过程,因为过程涉及到不同情况的分支流程,我用一张活动图把整个过程串了起来,方便大家理解。a5da45b0860f4af84529f672d4c44fe9.png关于redolog、binlog在图中做了注释,大家准备面试时不要忽略这部分。

总结

公众号图片上传后就不是高清的了,想要文中知识点的高清无水印大图的可以使用以下获取方式:

  • 关注公众号「网管叨bi叨」,在公众号消息框中回复关键字:面试速记

几张图就能整理一个知识点出来(其实画图画了三天才憋出来),本文的画图经验也整理在了我的付费专栏《程序员的全能画图课》

别看叫画图课,其实大部分内容是教大家工作中接到项目后,无论规模大小怎么对项目做需求拆解和分析,画图只是这些过程的高效管理和价值体现。

感兴趣的可以订阅,专栏已经更新完成,未来会再加更一些总结。 

订阅方式一:公众号专栏订阅入口:《程序员的全能画图课》

订阅方式二:扫描下方海报二维码订阅‍

33dc1eb9af6d1a2c6e8e4c132549094b.png

苹果手机推荐扫码订阅,不需要AppStore充值费率更低。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值