mysql慢速选择大表上的order by

mysql慢速选择大表上的order by,mysql,performance,select,sql-order-by,Mysql,Performance,Select,Sql Order By,我在mysql中存储了一个大表(基本上是一个日志),如下所示: CREATE TABLE `log` ( `ID_1` int(10) unsigned NOT NULL, `ID_2` int(10) unsigned NOT NULL, `DELTA` tinyint(3) unsigned NOT NULL, `ACTIVE` tinyint(1) NOT NULL, `DATA` bigint(20) unsigned NOT NULL,

我在mysql中存储了一个大表(基本上是一个日志),如下所示:

  CREATE TABLE `log` (
    `ID_1` int(10) unsigned NOT NULL,
    `ID_2` int(10) unsigned NOT NULL,
    `DELTA` tinyint(3) unsigned NOT NULL,
    `ACTIVE` tinyint(1) NOT NULL,
    `DATA` bigint(20) unsigned NOT NULL,
  ) ENGINE=MyISAM DEFAULT CHARSET=utf8$$
没有索引。使用随机数据在随机时刻插入数据,效果良好。然后,该表脱机(不进行读/写操作)。此时的表大小约为180米。我在ID_1、ID_2、DELTA、活动字段(全部4个,升序)上添加索引。它的工作速度相当快(3-4分钟)

现在,我正在尝试按ID_1、ID_2、DELTA、ACTIVE(与索引中的字段和顺序相同)的升序从表中获取所有数据,但select会在“排序结果”(在SHOW PROCESSLIST中)中保留一段时间,直到返回第一行。我试图提示/强制SELECT语句使用索引(即强制索引/使用索引),但没有任何区别。关于如何提高此类查询的响应速度的任何提示:

SELECT `ID_1`, `ID_2`, `DELTA`, `ACTIVE` FROM `log` ORDER BY `ID_1`, `ID_2`, `DELTA`, `ACTIVE` ASC;
?

这里也提出了类似的问题:-但没有答案。虽然发布这样的帖子是个好主意,但也许现在有人知道答案了


谢谢大家!

为了有效地对数据进行排序,必须使用
ORDER BY
子句中要使用的所有列添加一个复合索引。索引中列的顺序必须与
order BY
子句中列的顺序相同

在您的情况下,它将是:

ALTER TABLE `log` ADD INDEX mySortIndex(`ID_1`, `ID_2`, `DELTA`, `ACTIVE`);
要检查MySQL如何执行查询,请使用:

EXPLAIN SELECT `ID_1`, `ID_2`, `DELTA`, `ACTIVE` FROM `log` ORDER BY `ID_1`, `ID_2`, `DELTA`, `ACTIVE` ASC;
输出将告诉您使用了哪些索引

如果只需要已知数量的结果行,可以使用
LIMIT
阻止MySQL对整个表进行排序:

SELECT `ID_1`, `ID_2`, `DELTA`, `ACTIVE`
FROM `log` ORDER BY `ID_1`, `ID_2`, `DELTA`, `ACTIVE` ASC
LIMIT 100;

尝试增大MySQL的key\u buffer\u大小-默认值为128k,但对于这种类型的使用来说,这是一种很小的方法。有时建议使用高达25%的可用内存-请看,我也有同样的问题@dcg,你找到解决方案了吗?