我有一个查询,根据日期显示 id_units
的最后一个 id
。
我的查询是:
SELECT max(swg.id) AS id
FROM swg
WHERE swg.status != 0
AND sg.dateswg <= TIMESTAMPADD(DAY,(6-WEEKDAY('2015-12-28')),'2015-12-28')
GROUP BY swg.id_units
ORDER BY swg.id;
查询返回超过 2000 条记录,我认为有一种方法可以执行此查询。
我正在尝试像这样执行我的查询:
SELECT id
FROM (SELECT * FROM swg WHERE status != 0 AND dateswg <= TIMESTAMPADD(DAY,(6-WEEKDAY('2015-12-28')),'2015-12-28') ORDER BY id_units, id desc) x
GROUP BY id_units;
这是可行的,但我想知道是否有其他方法可以改进它
注意!
最佳答案
这是您的查询:
SELECT max(swg.id) AS id
FROM swg
WHERE swg.status <> 0 AND
swg.dateswg <= TIMESTAMPADD(DAY, 6 - WEEKDAY('2015-12-28'), '2015-12-28')
GROUP BY swg.id_units
ORDER BY MAX(swg.id);
这很难优化,因为索引不能同时用于这两种情况。您可以从查询中使用的所有四列上的复合索引开始:swg(dateswg, status, id_units, id)
关于mysql - 使用 MAX(id) 优化查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42118343/