Esiste un modo più efficiente di eseguire quanto segue?Restituire l'ultima riga di ogni "gruppo per" in MySQL
select *
from foo as a
where a.id = (select max(id) from foo where uid = a.uid group by uid)
group by uid;
)
Questa risposta sembra simile, ma è questa risposta il miglior modo di fare questo - How to select the first row for each group in MySQL?
Grazie,
Chris.
P.S. la tabella si presenta come:
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`)
)
dati:
id, uid, value
1, 1, hello
2, 2, cheese
3, 2, pickle
4, 1, world
risultati:
id, uid, value
3, 2, pickle
4, 1, world
Vedere http://www.barricane.com/2012/02/08/mysql-select-last-matching-row.html per maggiori dettagli.
Questa è una sottoquery correlata. Generalmente, una sottoquery non correlata si dimostrerà più veloce, come nell'esempio di Devart. – Strawberry
possibile duplicato di [Recupero dell'ultimo record in ogni gruppo] (http: // stackoverflow.it/questions/1313120/retrieving-the-last-record-in-each-group) –