MYSQL — GroupBy e Order não funcionam corretamente?

Paloma Macetko
2 min readFeb 8, 2020

--

Ola Gente!

Esta é uma pegadinha que acaba nos pegando.

Imagine que temos uma base com a seguinte estrutura:

Ou seja, a tabela armazena as datas em que nossos produtos foram editados.

Agora queremos retornar apenas a última modificação de cada produto, então fazemos a query abaixo:

E acabamos tendo o resultado abaixo:

Oé! Trouxe a primeira data em que os produtos foram modificados?

SIM! Nesta query, primeiro a base ira agrupar os dados, e depois, com os dados agrupados ira ordenar, ou seja, trazendo o primeiro registro relacionado a coluna agrupada, veja:

Independente da ordenação aplicada o GroupBy terá prioridade.

O mysql segue a seguinte ordem:

1. From
2. Where
3. Select
4. GroupBy <<< Primeiro
5. Having
6. OrderBy << Depois dos dados agrupados
7. Limit

Então como resolver?

Esqueça o Order e vamos buscar esta a informação direto na declaração de campos retornados, usando a função “max”, que traz o maior valor em um coluna:

E teremos o resultado:

E Pronto! Agora temos os produtos e a sua data de última modificação!

--

--

Paloma Macetko
Paloma Macetko

Written by Paloma Macetko

🏳️‍🌈 Mulher Trans 💻 Desenvolvedora Web

No responses yet