[英]MySQL - avoid filesort
我在查询中坚持使用filesort
EXPLAIN SELECT o.job_offerid
FROM job_offer AS o
WHERE o.status = 1
ORDER BY o.sequence ASC, o.active_updated_when DESC, o.created DESC
LIMIT 10;
该查询使用正确的索引,但是stil使用filesort。 EXPLAIN的输出:
select_type: SIMPLE
table: o
type: ref
possible_keys: status,status_sequence_active_updated_when_created
key: status_sequence_active_updated_when_created
key_len: 4
ref: const
rows: 15153
Extra: Using where; Using filesort
列的类型是:
状态int(13),序列int(13),active_updated_when(日期时间),创建(日期时间)
表MyISAM,MySQL版本5.6.21
我尝试在stackoverflow上查看类似的问题,但没有成功。
谢谢
编辑(添加没有其他列的表结构):
CREATE TABLE `job_offer` (
`job_offerid` int(13) NOT NULL AUTO_INCREMENT,
`sequence` int(13) NOT NULL DEFAULT '0',
`created` datetime NOT NULL,
`status` int(13) NOT NULL DEFAULT '1',
`active_updated_when` datetime DEFAULT NULL,
PRIMARY KEY (`job_offerid`),
KEY `status` (`status`),
KEY `sequence` (`sequence`),
KEY `created` (`created`),
KEY `active_updated_when` (`active_updated_when`),
KEY `status_sequence_active_updated_when_created` (`status`,`sequence`,`active_updated_when`, `created`),
FULLTEXT KEY `name` (`name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
在这种情况下,您无法避免文件排序。
为什么? 因此 :
在某些情况下,MySQL无法使用索引来解析ORDER BY
[...]
您混合使用ASC和DESC
如果要完全避免文件排序,这时最好的做法是重新考虑您的ORDER BY
子句。 这三个字段真的有必要吗? 您可以重构表以使用较少的字段进行排序吗? 另外,您是否可以将一个字段的含义更改为仅对所有字段使用DESC(或仅对ASC)?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.