Wenn Sie eine ANSICHT erstellen müssen, können Sie Folgendes verwenden:
CREATE VIEW First_Four AS
SELECT c1.*
FROM
Child_Table c1 LEFT JOIN Child_Table c2
ON c1.ParentID = c2.ParentID
AND (STR_TO_DATE(c1.`date`, '%m/%Y')>STR_TO_DATE(c2.`date`, '%m/%Y')
OR (STR_TO_DATE(c1.`date`, '%m/%Y')=STR_TO_DATE(c2.`date`, '%m/%Y')
AND c1.ID>c2.ID)
)
GROUP BY
c1.ID, c1.ParentID, c1.`Date`, c1.Data
HAVING
COUNT(c2.ID)<4
Ich betrachte die Felddaten als VARCHAR-Spalte, also müssen wir STR_TO_DATE verwenden, wenn dies nicht der Fall ist, können wir einfach c1.date
vergleichen mit c2.date
direkt.
Siehe fiddle hier .