字段说明:
type列,连接类型。一个好的SQL语句至少要达到range级别。杜绝出现all级别。
possible_keys: 表示查询时可能使用的索引。
key列,使用到的索引名。如果没有选择索引,值是NULL。可以采取强制索引方式。
key_len列,索引长度。
rows列,扫描行数。估算的找到所需的记录所需要读取的行数。
extra列,详细说明。注意,常见的不太友好的值,如下:Using filesort,Using temporary。
从这里可以看出,我们使用了索引,因为name是加了索引的;
tryp说明:

ALL: 扫描全表

index: 扫描全部索引树

range: 扫描部分索引,索引范围扫描,对索引的扫描开始于某一点,返回匹配值域的行,常见于between、<、>等的查询

ref: 使用非唯一索引或非唯一索引前缀进行的查找

eq_ref:唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配。常见于主键或唯一索引扫描

const, system: 单表中最多有一个匹配行,查询起来非常迅速,例如根据主键或唯一索引查询。system是const类型的特例,当查询的表只有一行的情况下, 使用system。like 模糊查询 前模糊或者 全模糊不走索引
explain select * from users u where u.name like '%mysql测试'
or 条件不走索引,只要有一个条件字段没有添加索引,都不走,如果条件都添加的索引,也不一定,测试
的时候发现有时候走,有时候不走,可能数据库做了处理,具体需要先测试一下

explain select * from users u where u.name = 'mysql测试' or u.password ='JspStudy'or 条件都是同一个索引字段,走索引
explain  select * from users u where u.name= 'mysql测试' or u.name='333'
使用 union all 代替 or 这样的话有索引例的就会走索引
explain

select * from users u where u.name = 'mysql测试'

union all

select * from users u where u.password = 'JspStudy'in 走索引
explain select * from users u where u.name in ('mysql测试','JspStudy')
not in 不走索引
explain select * from users u where u.name not in ('mysql测试','JspStudy')
is null 走索引
explain select * from users u where u.name is null
is not null  不走索引
explain select * from users u where u.name is not null
!=、<> 不走索引
explain select * from users u where u.name <> 'mysql测试'
隐式转换-不走索引(name 字段为 string类型,这里123为数值类型,进行了类型转换,所以不走索引,改为 '123' 则走索引)
explain select * from users u where u.name = 123
函数运算-不走索引
explain select *  from users u where  date_format(upTime,'%Y-%m-%d') = '2019-07-01'
and 语句,多条件字段,最多只能用到一个索引,如果需要,可以建组合索引
explain select * from users where id='4' and username ='JspStudy'