Возвращение «последней» строки каждой «группы по» в 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 Больше подробностей.

Ответы на вопрос(5)

Ваш ответ на вопрос