网站首页 > 技术文章 正文
新开一个系列,尝试把一些常见的面试题做成速记图,用来面试前临时抱佛脚。
最近我这个中年老登也在面试,形式所迫也是没办法。面试中除了问项目经验和管理经验外还经常会被问一些“八股”,说来惭愧,已经快六年没面过试了,很多以前倒背如流的东西,现在也很难想起来。
这情况就跟高中生高考完以为大学稳了,疯玩一暑假后发现自己没录取上要复读的感受差不多。
废话不多说,今天速记指南是:MySQL执行一条SQL语句的过程,这个相信大部分人准备面试的时候都背过,可以再来一起边听歌边快速浏览复习一下。
MySQL的基础架构
想知道SQL语句在MySQL中的执行过程,得先了解一下MySQL的基础架构,它的架构细节看下面这张图。
图片
MySQL 的架构分为:Server 层和 存储引擎层,他们各自的构成为 :
Server层:
- 连接器
- 查询缓存
- 分析器
- 优化器
- 执行器
存储引擎层:
- 各个存储引擎,实现存储引擎层定义的统一接口,为Server层提供统一的调用方式。
- 常见的存储引擎如上图。
这么多组件,每个都有它们单独的作用,我把他们都整理到了下面这张图里。
图片
Server层:
- 连接器:验证身份,管理连接
- 查询缓存:暂存结果集,再次查询直接返回,v8.0 后不再使用查询缓存
- 分析器:
词法分析,让MySQL知道要干什么 SELECT,还是UPDATE
语法分析,检查SQL语法错误
- 优化器:决定要用索引,连表查询决定关联顺序
- 执行器:确定对表有操作权限,调用表使用的存储引擎获取结构
MySQL基础架构有了初步了解后,我们来看SQL的执行过程,先来看查询SQL在MySQL中的执行过程
执行查询SQL的过程
一条查询SQL在MySQL中的执行过程,我都整理到下面这张图了
图片
- 客户端:发起查询,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中的执行过程,因为过程涉及到不同情况的分支流程,我用一张活动图把整个过程串了起来,方便大家理解。
图片
关于redolog、binlog在图中做了注释,大家准备面试时不要忽略这部分。
更多资讯,点击全场景直播解决方案-航天云网解决方案
- 上一篇: MySQL b-tree索引:快速加速数据查询与排序!
- 下一篇: MySQL中的索引
猜你喜欢
- 2024-11-19 MySQL常用的SQL提示
- 2024-11-19 MySQL 8.0-索引- 不可见索引(invisible indexes)
- 2024-11-19 数据库自学捷径-第七课 MySQL进阶-怎么提高搜索速度?索引
- 2024-11-19 Web端 SQL审核平台——Yearning Mysql
- 2024-11-19 MySQL性能管理及架构设计:SQL查询优化、分库分表
- 2024-11-19 深入浅出MySQL索引及优化分析,写出更高性能的SQL语句
- 2024-11-19 Linux运维面试sql语句
- 2024-11-19 图解MySQL:如何正确使用索引?
- 2024-11-19 看这篇就够了!MySQL 索引知识点超全总结
- 2024-11-19 SQL审核平台——Yearning Mysql
- 最近发表
-
- 用Cursor开启JAVA+AI生涯_javascirpt怎么开启
- 大数据调度服务监控平台_大数据调度是什么意思
- SpringBoot、MyBatis、Vue搭建一个Java企业应用开源框架源码分享
- 大数据技术之Flume_大数据volume的含义
- Jenkins运维之路(Slave容器节点)_jenkins slave工作原理
- 程序员自救指南:IDEA 卡成狗?我的 9G 堆内存调参表让你起飞 附避坑
- JMeter:一个简单的测试计划怎么做?
- Windows 命令行终端 PowerShell 美化计划
- JDK25即将发布!新特性概览_jdk52.0
- JDK 25 新特性极简总结(2025 年 9 月 16 日发布,LTS 长期支持)
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (77)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)