¿Hay alguna manera más eficiente de hacer lo siguiente?Devolviendo la 'última' fila de cada 'grupo por' en MySQL
select *
from foo as a
where a.id = (select max(id) from foo where uid = a.uid group by uid)
group by uid;
)
Esta respuesta parece similar, pero esta respuesta es la mejor forma de hacer esto - How to select the first row for each group in MySQL?
Gracias,
Chris.
P.S. la mesa se ve así:
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`)
)
de datos:
id, uid, value
1, 1, hello
2, 2, cheese
3, 2, pickle
4, 1, world
resultados:
id, uid, value
3, 2, pickle
4, 1, world
Ver http://www.barricane.com/2012/02/08/mysql-select-last-matching-row.html para más detalles.
Esta es una subconsulta correlacionada. En general, una subconsulta no correlacionada será más rápida, según el ejemplo de Devart. – Strawberry
posible duplicado de [Recuperando el último registro en cada grupo] (http: // stackoverflow.com/questions/1313120/retrieving-the-last-record-in-each-group) –