在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
前言: 索引下推(ICP)是针对MySQL使用索引从表中检索数据行的情况的优
索引下推可以减少存储引擎访问数据表的次数以及MySQL服务器访问存储引擎的次数。 是不是还有点懵呢,那就对了,毫无疑问上面这段话理解起来相当费劲,但请不要灰心,我将用最通俗易懂的语言来带你了解索引下推。 总结一下:
1、最左前缀原则 能使用该索引的情况如下: SELECT * FROM USER WHERE id = 1 SELECT * FROM USER WHERE id = 1 and name = 'zhangsan' SELECT * FROM USER WHERE id = 1 and name = 'zhangsan' and age = 18 不能使用该索引的情况如下: SELECT * FROM USER WHERE name = 'zhangsan' SELECT * FROM USER WHERE age = 18 SELECT * FROM USER WHERE name = 'zhangsan' and age = 18 对于联合索引 2、回表
这里着重说一下聚集索引,官方文档有以下描述
3、索引下推首先创建一个用户表 CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, `age` int DEFAULT 0, `class` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`), KEY `index_two` (`name`,`age`) ) ENGINE=InnoDB; //这张表增加一个复合索引 (`name`,`age`) 给表插入数据 INSERT INTO `student` (`name`, `age`, `class`) VALUES ('pengpeng', 21, '1'); INSERT INTO `student` (`name`, `age`, `class`) VALUES ('pengpeng', 22, '2'); INSERT INTO `student` (`name`, `age`, `class`) VALUES ('pengpeng', 23, '3'); INSERT INTO `student` (`name`, `age`, `class`) VALUES ('pengpeng', 24, '4'); INSERT INTO `student` (`name`, `age`, `class`) VALUES ('pengpeng', 25, '5'); 查询插入的数据如下 接下来explain下面这个SQL explain select * from student where name like 'peng%' and age = 23; 可以看到Extra字段显示为USING INDEX CONDITION,这就表明这个SQL使用了索引下推,我们分析下上面这个SQL语句:
问答区 问题1 当复合索引列为(name,age,address)时 以下SQL能使用索引吗? select * from student where name like 'peng%' and age = 23; 可以,遇到like会中断后续元素的匹配,但只能使用name这个字段,mysql会一直向右匹配直到遇到范围查询(>、<、between、like)就停止匹配。范围列可以用到索引,但是范围列后面的列无法用到索引。即索引最多用于一个范围列,因此如果查询条件中有两个范围列则无法全用到索引。 问题2 索引下推只能存在联合索引里吗? 是的,非联合索引无法使用索引下推。 问题3 索引下推在哪些情况下无法使用?
问题4 索引下推如何开启和关闭? // 索引下推默认是开启的 set optimizer_switch='index_condition_pushdown=off'; // 关闭 set optimizer_switch='index_condition_pushdown=on'; // 开启 总结 索引下推在非主键索引上的优化,可以有效减少回表的次数,大大提升了查询的效率,在平时工作中可以根据业务情况通过优化索引来达到使用索引下推,提高业务吞吐量。 到此这篇关于MySQL索引下推详细的文章就介绍到这了,更多相关MySQL索引下推内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论