sql >> Base de Datos >  >> RDS >> Mysql

Orden condicional de MySQL por dos columnas (igualmente importantes)

Debe encontrar la última fecha para cada categoría en una subconsulta, unir esta subconsulta a su tabla y ordenar por 3 campos:

SELECT p.* FROM products p
JOIN
( SELECT category_id, MAX(date) as category_date FROM products
  GROUP BY category_id ) pg
ON p.category_id = pg.category_id
ORDER BY pg.category_date DESC, p.category_id, p.date DESC