MySQL 查询执行流程

在开发过程中编写sql时,常常遇见查询慢的问题,在网上也查询了很多优化的方法,比如减少sql嵌套、减少关联、运用索引等,但究其根部不知道mysql是怎么执行查询语句的,专门研究了一下《高性能MySQL》,跟大家分享一下。

《高性能mysql》查询性能优化部分:当希望mysql能够以更高的性能运行查询时,最好的办法就是弄清楚MySQL是如何优化和执行查询的。一旦理解这一点,很多查询优化工作实际上就是遵循一些原则让优化器能够按照预想的合理的方式运行。
那我们就看一下当想MySQL发送一个请求的时候,MySQL到底做了什么?
这里写图片描述

步骤:

  1. 客户端发送一条查询sql给服务器
  2. 服务器先检查缓存,如果命中了缓存,则立刻返回存储在缓存中的结果;否则进入下一个阶段。
  3. 服务器端进行sql解析、预处理,再由优化器生成对应的执行计划。
  4. mysql根据优化器生成的执行计划,调用存储引擎的API来执行查询。
  5. 将结果返回给客户端。

上面的每一步都比想象的复杂。我们会看到在每个阶段查询处于何种状态。查询优化器是其中特别复杂也特别难理解的部分。还有很多的例外情况,例如当查询使用绑定变量后,执行路径会所不同,我会在以后的博客中继续写这部分。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值