mysql学习
连接器简单总结一下:与客户端进行 TCP 三次握手建立连接;校验客户端的用户名和密码,如果用户名或密码不对,则会报错;如果用户名和密码都对了,会读取该用户的权限,然后后面的权限逻辑判断都基于此时读取到的权限
解析器词法分析,语法分析
执行 SQL每条SELECT 查询语句流程主要可以分为下面这三个阶段:prepare 阶段,也就是预处理阶段;optimize 阶段,也就是优化阶段;execute 阶段,也就是执行阶段;
预处理器
优化器经过预处理阶段后,还需要为 SQL 查询语句先制定一个执行计划,这个工作交由「优化器」来完成的。优化器主要负责将 SQL 查询语句的执行方案确定下来
要想知道优化器选择了哪个索引,我们可以在查询语句最前面加个 explain 命令,这样就会输出这条 SQL 语句的执行计划
- 覆盖索引
执行器经历完优化器后,就确定了执行方案,接下来 MySQL 就真正开始执行语句了,
最后总结:连接器:建立连接,管理连接、校验用户身份;查询缓存:查询语句如果命中查询缓存则直接返回,否则继续往下执行。MySQL 8.0 已删除该模块;解析 SQL,通过解析器对 SQL 查询语句进行词法分析、语法分析,然后构建语法树,方便后续模块读取表名、字段、语句类型;执行 SQL:执行 SQL 共有三个阶段:预处理阶段:检查表或字段是否存在;将 select 中的 符号扩展为表上的所有列。优化阶段:基于查询成本的考虑, 选择查询成本最小的执行计划;执行阶段:根据执行计划执行 SQL 查询语句,从存储引擎读取记录,返回给客户端;
转载自:https://segmentfault.com/a/1190000042050790