sql >> Database teknologi >  >> RDS >> Mysql

Spørg forældre og børn i selvhenvisningstabel

Det testede ikke, men jeg tror, ​​at dette også burde virke i MySQL:

ORDER BY CASE WHEN parent_id=-1 THEN id ELSE parent_id END, created_at

Rediger: Hvis du ikke kan antage, at Id'erne stiger i samme logiske rækkefølge som kommentarerne, bliver det lidt mere komplekst:

SELECT parent_id,id,created_at parent_date,null child_date,content
    FROM Comments
    WHERE parent_id=-1
UNION
SELECT c.parent_id,c.id,p.created_at as parent_date,c.created_at as child_date,c.content
FROM Comments c
    JOIN (SELECT id,created_at,content
            FROM Comments
            WHERE parent_id=-1
            GROUP BY id,created_at,content) p ON p.id=c.parent_id
ORDER BY parent_date,child_date



  1. Hvordan finder man ud af, at brugeren er til stede i Sqlite-databasen ved hjælp af Android?

  2. Sådan konverteres Unix-epoke til et tidsstempel

  3. CURRENT_TIME Eksempler – MySQL

  4. MySQL sammensat indeks bliver ikke brugt