是什么
使用explain可以模拟优化器执行SQL查询语句,从而知道MySQL怎么处理你的SQL语句的,分析你的查询语句和表结构的性能瓶颈。
可以做什么
读取表的顺序
哪些索引能够被使用
数据读取操作的操作类型
哪些索引能够被实际使用
表之间的引用
每张表有多少行被物理查询
怎么用
在你书写的SQL语句加一个单词 - explain,然后将 explain + SQL执行后会出现一个表,这个表会告诉你MySQL优化器是怎样执行你的SQL的
explain各个字段代表的意思
id :select查询的序列号,包含一组数字,表示查询中执行select子句或操作表的顺序
select_type :查询类型 或者是 其他操作类型
table :正在访问哪个表
partitions :匹配的分区
type :访问的类型
possible_keys :显示可能应用在这张表中的索引,一个或多个,但不一定实际使用到
key :实际使用到的索引,如果为NULL,则没有使用索引
key_len :表示索引中使用的字节数,可通过该列计算查询中使用的索引的长度
ref :显示索引的哪一列被使用了,如果可能的话,是一个常数,哪些列或常量被用于查找索引列上的值
rows :根据表统计信息及索引选用情况,大致估算出找到所需的记录所需读取的行数
filtered :查询的表行占表的百分比
Extra :包含不适合在其它列中显示但十分重要的额外信息
MySQL的EXPLAIN命令用于分析SQL查询的执行计划,帮助识别查询性能瓶颈。它显示了表的读取顺序、索引使用、操作类型等信息。通过分析`id`、`select_type`、`type`、`key`、`rows`等字段,可以了解查询效率,并据此优化查询。了解EXPLAIN的使用能有效提升数据库查询性能。
3779

被折叠的 条评论
为什么被折叠?



