Есть ли более эффективный способ сделать следующее?Возврат «последней» строки каждой «группы по» в MySQL
select *
from foo as a
where a.id = (select max(id) from foo where uid = a.uid group by uid)
group by uid;
)
Этот ответ похож, но это ответ на лучший способ сделать это - How to select the first row for each group in MySQL?
Спасибо,
Криса.
P.S. таблица выглядит следующим образом:
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 для более подробной информации.
Это коррелированный подзапрос. Как правило, некоррелированный подзапрос будет работать быстрее, как пример Деварта. – Strawberry
Возможный дубликат [Получение последней записи в каждой группе] (http: // stackoverflow.com/questions/1313120/retrieve-the-last-record-in-each-group) –