高新园区规划建设局网站,网站建设特定开发,怎样打开网站,wordpress的简单介绍今天我们正式进入研究explain命令得到的SQL执行计划的内容了#xff0c;只要把explain分析得到的SQL执行计划都研究透彻#xff0c;完全能看懂#xff0c;知道每个执行计划在底层是怎么执行的#xff0c;那么后面学习SQL语句的调优就非常容易了。
首先#xff0c;我们现在…今天我们正式进入研究explain命令得到的SQL执行计划的内容了只要把explain分析得到的SQL执行计划都研究透彻完全能看懂知道每个执行计划在底层是怎么执行的那么后面学习SQL语句的调优就非常容易了。
首先我们现在应该都知道每条SQL语句mysql都会经过成本和规则的优化对这个SQL选择对应的一些访问方法和顺序包括做一些特殊的改写确保执行效率是最优的然后优化过后就会得到一个执行计划。
这个执行计划其实真没那么神秘如果你把之前的内容都学习的比较透彻的话就会知道所谓的执行计划落实到底层无非就是先访问哪个表用哪个索引还是全表扫描拿到数据之后如何去聚簇索引回表是否要基于临时磁盘文件做分组聚合或者排序其实这个计划到最后就是这点东西。
平时我们只要用类似于explain select * from table这种SQL前面加一个explain命令就可以轻松拿到这个SQL语句的执行计划。
首先当你执行explain命令之后拿到的执行计划可能是类似下面这样的东西
id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |±—±------------±------±-----------±-----±--------------±-----±--------±-----±-----±---------±---------------| 1 | SIMPLE | NULL | NULL | NULL | NULL | NULL | NULL | NULL | NULL | NULL | No tables used |
大家看到那所谓的id、select_type、table、partitions、type之类的东西了吗其实这些就是所谓的执行计划里包含的东西
大致来说如果是一个简单的单表查询可能这里就只有一条数据也就是代表了他是打算如何访问这一个表而已。
但是如果你的SQL语句极为的复杂可能这里会有很多条数据因为一个复杂的SQL语句的执行是要拆分为很多步骤的比如先访问表A接着搞一个排序然后来一个分组聚合再访问表B接着搞一个连接类似这样子。
好那么接下来我们就先来研究一下这个所谓的执行计划里包含的各个字段都是什么意思首先是id这个东西
这个id呢就是说每个SELECT都会对应一个id其实说穿了就是一个复杂的SQL里可能会有很多个SELECT也可能会包含多条执行计划每一条执行计划都会有一个唯一的id这个没啥好说的。
select_type顾名思义说的就是这一条执行计划对应的查询是个什么查询类型table就是表名意思是要查询哪个表partitions是表分区的概念这个所谓的分区表我们会在后面给大家讲这里先不用太关注他。
针对当前这个表的访问方法这个之前我们都讲过很多比如说const、ref、range、index、all之类的分别代表了使用聚簇索引、二级索引、全表扫描之类的访问方式。
他是跟type结合起来的意思就是说你type确定访问方式了那么到底有哪些索引是可供选择可以使用的呢这都会放这里。key就是在possible_keys里实际选择的那个索引而key_len就是索引的长度。
ref就是使用某个字段的索引进行等值匹配搜索的时候跟索引列进行等值匹配的那个目标值的一些信息。rows是预估通过索引或者别的方式访问这个表的时候大概可能会读取多少条数据。filtered就是经过搜索条件过滤之后的剩余数据的百分比。extra是一些额外的信息不是太重要。
好了今天就先看到这里明天我们继续讲解对真实的SQL语句分析得到的执行计划会长什么样子让大家彻底能看懂执行计划。