mysql下载不了怎么办MySQL的orderby不使⽤索引的解决办法
这是项⽬中遇到的问题,为多表联合查询,我这边简单描述⼀下:
SQL语句是这样的:select * from A a left join B b on a.id = b.device_id left join C c on a.id = c.alarm_id ...... where (中间有查询条件,但是默认为空) order by a.alarm_time
这⾥我创建了3个索引,⼀个是a表的alarm_time:create index idx_A_alarm_time on A(alarm_time),因为d.device_id并不是主键,⽽且可以为null,因此也B表创建了⼀个索引,然后给C表的alarm_id也建⽴了⼀个索引
这时候有意思的就来了:
1.当where 条件⾥⾯有alarm_time查询的时候,这个查询会⽤到A表的索引
2.当where条件不在的时候,也就是说没有where条件的时候,这个查询就没有⽤到索引,显⽰的是Using filesort,这可是⼀个很严重的问题了
3.⼀开始我以为是关联查询的问题,于是测试了各种⼦查询,然后⼜遇到不同的坑,⼦查询虽然能避免上⾯的问题,但是我惊讶的发现这个⼦查询⾥⾯加order by和不加没有任何区别。也就是说mysql内部的⼦查询order by 失效了(问题是5.7之后,要解决只有加limit 限制),于是加了limit后还是会使⽤filesort,⼦查询等于没查,⼜回到起点
4.于是我测试了单张表,在单表下测试这个order by 有没有使⽤索引,这⾥我为了不泄漏数据,使⽤⾃⼰测试的数据,这⾥插⼊4条数据,⽤做测试⾜够了,写存储过程也⿇烦。
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for `user`
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL,
`age` int(3) DEFAULT NULL,
`descri` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES ('1', '张三', '1', '1');
INSERT INTO `user` VALUES ('2', '李四', '2', '1');
INSERT INTO `user` VALUES ('3', '王五', '3', '1');
INSERT INTO `user` VALUES ('4', '码⼦', '4', '1');
5.在name字段创建索引
这是查看表存在的索引。
再运⾏这段代码explain select * from user order by name ,看看有没有使⽤到索引 ,出现filesort,并没有使⽤到索引
6.因此问题就很明⽩了,连表查询表⽰我不背这个锅,那么怎么解决呢?
我个⼈的解决⽅式是强制mysql使⽤索引
SQL语句:select * from user force index(idx_user_name),这样能够达到index级别,全表查询也算可以了

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。