调用explain
explain可以查看查询计划的信息,
如果sql语句中包含子查询,mysql依然会执行子查询,将结果放到一个临时表中。然后完成外层的优化查询
## EXPLAIN中的列
explain中总是有相同的列。
### id 列
这个id包含一个标号,标识select所属的行。如果语句中没有子查询或者联合,id唯一。
mysql将查询分为简单查询和复杂查询,复杂查询分为子查询、派生表(FROM中的子查询)、union查询。
### select_type 列
这一列显示对应的行是简单查询还是复杂查询。,如果是简单 查询 就是simple。如果是复杂查询,则是以下的几种值
1. SUBQUERY
包含在select列表中的select
```sql
select (select id from user) from user
```
2. DERIVED
DERIVED值用来表示包含在from子查询中的select。
```sql
select id from (select id from user where id >100);
```
3. UNION
在union中的第二个值和select 都被标记为union
4. union result
用来从临时表检索结果的select被标记为union result
### table 列
对应访问的表。
### type 列
mysql决定查找表中的行
- all
全表扫描。
- index
跟全表扫描一样,只是按照索引的顺序进行。优点避免了排序,缺点就是按照整个索引读取整个表的开销。
- range
范围扫描。就是一个有限制的索引扫描,开始于索引的一点,结束到匹配的值。比如 between 或者where 带有 范围的条件
- ref
这是一种索引访问,返回匹配到某个单个值的行,一般是非唯一索引或者非唯一索引的前缀索引。
- eq_ref
使用这种索引查找,一般是通过唯一索引或者主键索引查找的时候看到
- const system
mysql对查询的部分进行优化转成一个常量的时候,比如把一行中的主键放入到where条件中
```sql
select * from user where name = id ;
```
- null
mysql在优化阶段分解查询语句,在执行阶段不用访问表或者访问索引。
### possible_keys
这列显示的是mysql可以使用的索引
### key 列
决定了mysql 采用哪个索引来对表的访问。
### key_len 列
mysql在索引使用的字节数
### ref列
显示之前的表在key列记录的索引,中,查找值所用的列或常量。
### rows 列
估算查到需要结果的而读取到的行数。
### fiteread 列
查询记录和总记录的一个百分比
### extra 列
额外的信息
- using index 使用覆盖索引
- using where
- using temproary 使用临时表
- using filesort 使用文件排序
-
- PC
- IO模型
- Inode介绍
- Linux
- Linux基本操作命令
- Linux网络相关命令
- Crontab计划任务
- Shell
- Sed命令
- Awk命令
- LAMP/LNMP
- PHP
- 基本语法
- 面向对象
- 错误和异常处理
- 命名空间
- PHP7
- 正则表达式
- Hashtable
- 变量的内部实现
- PHP-FPM
- PHP运行原理
- swoole
- mysql
- SQL标准
- mysql三范式
- 存储引擎
- Mysql事务
- Mysql索引
- Mysql优化
- Explain
- MySQL索引原理及慢查询优化
- MongoDb
- 计算机网络
- IP协议
- TCP(传输控制协议)
- UDP(用户数据报协议)
- HTTP 协议
- HTTPS
- HTTP的基本优化
- Websocket协议
- 版本控制器
- Git
- Svn
- 数据结构
- 数组
- 链表
- 算法