面试官:“讲讲一条MySQL语句执行过程”
大家好,我是肥哥!一个专注于打发时间的肥宅!
一条SQl查询究竟经过了怎样的波折才能返回查询结果集?平时使用MySQL,我们多数将其作为黑盒使用,一条语句进去,结果集出来,至于其内部实现机制,基本不关注。本篇文章将以萌新应聘员小白囧囧和首席面试官大肥的一段面试对话揭开其中神秘的面纱。
内容补充
MySQL层次细分
这里网上看到一张MySQL层次图,画的非常好。
连接层:最上层是一些客户端和连接服务。主要完成一些类似于连接处理、授权认证、及相关的安全方案。在该层上引入了线程池的概念,为通过认证安全接入的客户端提供线程。同样在该层上可以实现基于SSL的安全链接。服务器也会为安全接入的每个客户端验证它所具有的操作权限。
服务层:第二层服务层,主要完成大部分的核心服务功能, 包括查询解析、分析、优化、缓存、以及所有的内置函数,所有跨存储引擎的功能也都在这一层实现,包括触发器、存储过程、视图等。
引擎层:第三层存储引擎层,存储引擎真正的负责了MySQL中数据的存储和提取,服务器通过API与存储引擎进行通信。不同的存储引擎具有的功能不同,这样我们可以根据自己的实际需要进行选取。
存储层:第四层为数据存储层,主要是将数据存储在运行于该设备的文件系统之上,并完成与存储引擎的交互。
更多精彩内容,欢迎关注微信公众号:囧么肥事 (或搜索jiongmefeishi)