MySQL explain extra列里的Using where到底是什么意思

文章创建了一个名为actor的测试表,并插入数据。接着通过EXPLAIN分析了SELECT*FROMactorWHEREname=a的查询执行计划,指出在name列没有索引的情况下,会使用Usingwhere,这可能导致效率低下,建议通过添加索引来优化查询性能。
摘要由CSDN通过智能技术生成

1.先建一张测试表

CREATE TABLE actor (
id int(11) not null,
name varchar(45) default null,
update_time datetime default null,
primary key (id)
) ENGINE = INNODB default CHARSET = utf8;

insert into actor values (1, 'a', '2017-12-22 15:27:18'), (2, 'b', '2017-12-22 15:27:18'), (3, 'c', '2017-12-22 15:27:18');

2.看一下表中数据
在这里插入图片描述
3.执行以下sql数据

explain select * from actor where name = 'a';

4.查看执行计划结果
在这里插入图片描述
5.再看官方文档说明
在这里插入图片描述

##总结
什么情况下才会出现Using where
1.使用where查询条件
2.查询的列name未被索引覆盖

个人理解:除非特别希望通过全表扫描来过滤数据,否则这条sql语句可能有问题,需要通过索引来优化。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值