簡體   English   中英

MySQL-避免文件排序

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM