Tutaj to doskonały artykuł w oficjalnej dokumentacji MySQL:
Cytat:
Wiersze utrzymujące maksimum grupy określonej kolumny
Zadanie:dla każdego artykułu znajdź sprzedawcę lub sprzedawców z najdroższą ceną.
Ten problem można rozwiązać za pomocą podzapytania takiego jak to:
SELECT article, dealer, price
FROM shop s1
WHERE price=(SELECT MAX(s2.price)
FROM shop s2
WHERE s1.article = s2.article);
W poprzednim przykładzie użyto skorelowanego podzapytania, które może być nieefektywne (patrz Sekcja 13.2.10.7, „Skorelowane podzapytania”). Inne możliwości rozwiązania problemu to użycie nieskorelowanego podzapytania w klauzuli FROM lub LEFT JOIN.
Nieskorelowane podzapytanie:
SELECT s1.article, dealer, s1.price
FROM shop s1
JOIN (
SELECT article, MAX(price) AS price
FROM shop
GROUP BY article) AS s2
ON s1.article = s2.article AND s1.price = s2.price;
LEWY DOŁĄCZ:
SELECT s1.article, s1.dealer, s1.price
FROM shop s1
LEFT JOIN shop s2 ON s1.article = s2.article AND s1.price < s2.price
WHERE s2.article IS NULL;
LEFT JOIN działa na tej podstawie, że gdy s1.price osiąga maksymalną wartość, nie ma s2.price o większej wartości, a wartości wierszy s2 będą równe NULL.