id, type, nr, version, client
i chciałbym wybrać tylko te produkty, gdzie wersja jest najwyższa.
SELECT p.id, p.client, p.number, p.version, c.name, FROM products p INNER JOIN customers c ON p.client=c.id GROUP BY p.client, p.number, p.type ORDER BY p.version DESC
i to działa jakoś dziwnie, bo czasami trafia w najwyższą wersję, a czasami nie.
Przykładowo jest sześć wersji to on pokazuje czwartą, wcześniej jeszcze miałem dołożone max(version)
SELECT p.id, p.client, p.number, max(p.version), c.name, FROM products p INNER JOIN customers c ON p.client=c.id GROUP BY p.client, p.number, p.type ORDER BY p.version DESC
to rzeczywiście pokazywał wersję szóstą ale ID było z wersji czwartej
O czym zapomniałem?
Już sobie przypomniałem:
SELECT p.id, p.client, p.number, max(p.version), c.name FROM (SELECT * FROM products ORDER BY version DESC) p INNER JOIN customers c ON p.client=c.id GROUP BY p.client, p.number, p.type ORDER BY p.version DESC