gpt4 book ai didi

mysql - 使用 MAX(id) 优化查询

转载 作者:行者123 更新时间:2023-11-29 19:26:18 25 4
gpt4 key购买 nike

我有一个查询,根据日期显示 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com