ЭТО НЕ ТАКОЙ ВОПРОС, ЧЕМ: Используя LIMIT внутри GROUP BY, чтобы получить N результатов для каждой группы?
но я допускаю, что это похоже.
Мне нужно выбрать первые 2 строки на человека. строки упорядочиваются по Полученному году
Проблема: есть вероятность, что в тот же месяц были введены 2 данных (дата введена в ГГГГ-ММ)
Запрос, который я пришел с (по указанному вопросу), застревает в цикле BIG.
SELECT *
FROM `table_data` as b
WHERE (
SELECT count(*) FROM `table_data` as a
WHERE a.Nom = b.Nom and a.year < b.year
) <= 2;
Пример данных:
A | year | Nom
---------------------
b | 2011-01 | Tim
---------------------
d | 2011-01 | Tim
---------------------
s | 2011-01 | Tim
---------------------
a | 2011-03 | Luc
---------------------
g | 2011-01 | Luc
---------------------
s | 2011-01 | Luc
При экспорте:
A | year | Nom
---------------------
b | 2011-01 | Tim
---------------------
d | 2011-01 | Tim
---------------------
a | 2011-03 | Luc
---------------------
g | 2011-01 | Luc