[MySQL]Query的性能优化分析(二)
MySQL Query Optimizer MySQL Query Optimizer是MySQL中专门负责优化SELECT语句的模块,其主要功能是:通过计算分析系统中收集到的统计信息,为客户端请求的Query提供MySQL认为最优的执行计划 1 。 优化器执行过程: 客户端向MySQL发起Query请求; 命令解析器模块完成请求分类,区别出SELECT并转发给MySQL Query Optimizer(查询优化器); 查询优化器对整条Query进行优化,处理掉一些常量表达式的预算,直接换算成常量值; 查询优化器对Query中的查询条件进行简化和转换,如去掉一些无用或显而易见的条件、结构调整等; 分析Query中是否有Hint消息,是否可以通过Hint信息完全确定该Query的执行计划; 若没有Hint信息或不足以完全确定执行计划,则会读取所涉及对象的统计信息,根据Query进行写相应的计算分析,得出最后的执行计划。 查看执行计划:Explain Explain的作用 使用EXPLAIN关键字可以通过模拟优化器执行SQL查询语句了解MySQL是如何处理SQL语句,从而分析查询语句或是表结构中的性能瓶颈。 使用Explain可以了解到: 表的读取顺序:通过执行计划中的id判断 数据读取操作的操作类型:通过执行计划中的select_type判断 哪些索引可以使用