发布时间:2025-11-05 06:53:53 来源:技术快报 作者:人工智能
新开一个系列,图解尝试把一些常见的行条面试题做成速记图,用来面试前临时抱佛脚。过程
最近我这个中年老登也在面试,图解形式所迫也是行条没办法。面试中除了问项目经验和管理经验外还经常会被问一些“八股”,过程说来惭愧,图解已经快六年没面过试了,行条很多以前倒背如流的过程东西,现在也很难想起来。图解
这情况就跟高中生高考完以为大学稳了,行条疯玩一暑假后发现自己没录取上要复读的过程感受差不多。
废话不多说,图解今天速记指南是行条:MySQL执行一条SQL语句的过程,这个相信大部分人准备面试的过程时候都背过,可以再来一起边听歌边快速浏览复习一下。
想知道SQL语句在MySQL中的执行过程,得先了解一下MySQL的基础架构,它的架构细节看下面这张图。亿华云
图片
MySQL 的架构分为:Server 层和 存储引擎层,他们各自的构成为 :
Server层:
连接器查询缓存分析器优化器执行器存储引擎层:
各个存储引擎,实现存储引擎层定义的统一接口,为Server层提供统一的调用方式。常见的存储引擎如上图。这么多组件,每个都有它们单独的作用,我把他们都整理到了下面这张图里。
图片
Server层:
连接器:验证身份,管理连接查询缓存:暂存结果集,再次查询直接返回,v8.0 后不再使用查询缓存分析器:词法分析,让MySQL知道要干什么 SELECT,还是UPDATE
语法分析,检查SQL语法错误
优化器:决定要用索引,连表查询决定关联顺序执行器:确定对表有操作权限,调用表使用的存储引擎获取结构MySQL基础架构有了初步了解后,我们来看SQL的执行过程,先来看查询SQL在MySQL中的执行过程
一条查询SQL在MySQL中的执行过程,我都整理到下面这张图了
图片
验证用户: 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在MySQL中的执行过程,因为过程涉及到不同情况的分支流程,我用一张活动图把整个过程串了起来,方便大家理解。
图片
关于redolog、binlog在图中做了注释,大家准备面试时不要忽略这部分。
随便看看