我正在尝试从表中选择N个最后的唯一关键字,该表的结构如下:
id | keyword | digit
1 | TEXT1 | 123
2 | TEXT2 | 125
...
3 | TEXT3 | 123with查询:
SELECT id, keyword FROM table
WHERE digit = 123
AND id IN
(SELECT MAX(id) FROM table GROUP by keyword)
ORDER BY id DESC LIMIT 10当limit为10 - 20时,所需时间不到一秒,但如果limit从50开始,则查询时间从3秒或更长开始。
分选是邪恶的。我是否可以加速这样的查询?
发布于 2013-01-17 03:15:33
尝尝这个
SELECT MAX(id) max, keyword FROM table
WHERE digit = 123
GROUP BY keyword
ORDER BY max DESC LIMIT 10发布于 2013-01-17 03:28:56
尝尝这个
SELECT MAX(id) as id, keyword FROM table
WHERE digit = 123
GROUP BY keyword
ORDER BY id DESC LIMIT 10欢迎光临。
https://stackoverflow.com/questions/14365938
复制相似问题