Istnieje wiele alternatyw, aby rozwiązać ten problem, zalecam dołączenie do podzapytania, które oddzielnie pobiera najnowszy ID
(przy założeniu, że kolumna to AUTO_INCREMENT
red ) dla każdego store_ID
.
SELECT a.*
FROM tableName a
INNER JOIN
(
SELECT store_ID, MAX(ID) max_ID
FROM tableName
GROUP BY store_ID
) b ON a.store_ID = b.store_ID AND
a.ID = b.max_ID
dla lepszej wydajności upewnij się, że masz indeks w tych kolumnach:ID
i store_id
.
AKTUALIZACJA 1
jeśli chcesz mieć limit dla każdego rekordu, użyj tego poniżej,
SELECT ID, product_Name, store_ID
FROM tableName a
WHERE
(
SELECT COUNT(*)
FROM tableName b
WHERE b.store_ID = a.store_ID AND b.ID >= a.ID
) <= 2;