首页 > 数据库 > MySQL > 正文

mysql explain的用法(使用explain优化查询语句)

2024-07-24 12:52:48
字体:
来源:转载
供稿:网友

首先我来给一个简单的例子,然后再来解释explain列的信息。

表一:catefory 文章分类表:

CREATE TABLE IF NOT EXISTS `category` ( `id` smallint(5) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL DEFAULT '', PRIMARY KEY (`id`) ) ENGINE=MyISAM INSERT INTO `test`.`category` VALUES (NULL , '分类1'); INSERT INTO `test`.`category` VALUES (NULL , '分类2'); INSERT INTO `test`.`category` VALUES (NULL , '分类3');

表二:article文章表:

CREATE TABLE IF NOT EXISTS `article` ( `aid` int(11) NOT NULL, `cid` int(11) NOT NULL, `content` text NOT NULL, PRIMARY KEY (`aid`), KEY `cid` (`cid`)) ENGINE=MyISAMINSERT INTO `test`.`article` (`aid`, `cid`, `content`) VALUES ('', '7', '错新站长站(Vevb.com)教程');

执行explain:

EXPLAIN SELECT name, contentFROM category, articleWHERE category.id = article.cid

得到结果:

EXPLAIN列的解释:

id:选定的执行计划中查询的序列号。表示查询中执行select子句或操作表的顺序,id值越大优先级越高,越先被执行。id相同,执行顺序由上至下。

select_type:查询类型 说明

1、SIMPLE:简单的select查询,不使用union及子查询
2、PRIMARY:最外层的select查询
3、UNION:UNION中的第二个或随后的select查询,不依赖于外部查询的结果集
4、DEPENDENT UNION:UNION中的第二个或随后的select查询,依赖于外部查询的结果集
5、UNION RESULT: UNION查询的结果集SUBQUERY子查询中的第一个select查询,不依赖于外部查询的结果集
6、DEPENDENT SUBQUERY:子查询中的第一个select查询,依赖于外部查询的结果集DERIVED用于from子句里有子查询的情况。
MySQL会递归执行这些子查询,把结果放在临时表里。
7、UNCACHEABLE SUBQUERY:结果集不能被缓存的子查询,必须重新为外层查询的每一行进行评估
8、UNCACHEABLE UNION:UNION中的第二个或随后的select查询,属于不可缓存的子查询

table:显示这一行的数据是关于哪张表的
type:这是重要的列,显示连接使用了何种类型。从最好到最差的连接类型为const、eq_reg、ref、range、index和ALL
all: full table scan ;mysql将遍历全表以找到匹配的行;
index : index scan; index 和 all的区别在于index类型只遍历索引;
range:索引范围扫描,对索引的扫描开始于某一点,返回匹配值的行,常见与between ,< ,>等查询;
ref:非唯一性索引扫描,返回匹配某个单独值的所有行,常见于使用非唯一索引即唯一索引的非唯一前缀进行查找;
eq_ref:唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配,常用于主键或者唯一索引扫描;

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表