Возвращение «последней» строки каждой «группы по» в MySQL
Есть ли более эффективный способ сделать следующее?
select *
from foo as a
where a.id = (select max(id) from foo where uid = a.uid group by uid)
group by uid;
)
Этот ответ выглядит аналогично, но является ли этот ответ лучшим способом сделать это -Как выбрать первый ряд для каждой группы в MySQL?
Спасибо,
Крис.
Постскриптум таблица выглядит так:
CREATE TABLE foo (
id INT(10) NOT NULL AUTO_INCREMENT,
uid INT(10) NOT NULL,
value VARCHAR(50) NOT NULL,
PRIMARY KEY (`id`),
INDEX `uid` (`uid`)
)
данные:
id, uid, value
1, 1, hello
2, 2, cheese
3, 2, pickle
4, 1, world
Результаты:
id, uid, value
3, 2, pickle
4, 1, world
Видетьhttp://www.barricane.com/2012/02/08/mysql-select-last-matching-row.html Больше подробностей.