一条sql从客户端发起,在mysql中经过了一系列的流程,归结为如下图所示:
客户端提交一条sql语句,先在查询缓存中查询,如果缓存没有命中,将会进行查表操作。查表的流程总结过为如下:
(1)将sql交给解析器处理,生成一个解析树。
(2)预处理器会处理解析器,重新生成一个解析器,这个过程中将会改写sql。
(3)改写后的解析器交给查询优化器,查询优化器生成sql的执行计划。
(4)执行计划交给执行引擎调用存储引擎的的API接口,查询数据。
(5)最终的结果由执行引擎返回给客户端,如果看,开启查询缓存的话将会返回给客户端。
1、查询优化器
查询优化器的主要作用是用来生成sql的执行计划,查询优化器是数据库的核心大脑所在,从某种意义上来说,优化sql,本质是理解优化器的执行行为。在mysql中优化的依据是sql的执行成本,执行计划的生成是基于成本的,成本的决定是依据sql的执行行数。优化器工作的前提是了解数据,工作的目的是解析数据,生成执行计划。
2、查询优化器执行过程
如上图所示:
查看执行计划可以采用explain关键字。
EXPLAIN SELECT * from addr_longxi
当我们发现sql的执行计划不合理时,可以通过添加索引和强制驱动表的顺序,通过hints方式干预sql的执行计划。另外,mysql优化器的一些参数也可以进行修改,来控制优化器的一些行为。
2. 优化器开关
·show variables like 'optimizer_switch
3.Processlist
另一种观测MySQL行为的常用手段就是Processlist。通过Processlist,我们可以看到当前在MySQL中执行的所有SQL语句,有没有异常的会话或比较特殊的SQL状态。查看会话操作可以通过2种途径:
第一,show [full] processlist;
第二,information_schema.processlist。
常见异常行为有:
阅读量:2015
点赞量:0
收藏量:0