sql >> Databasteknik >  >> RDS >> Oracle

SQL SELECT för att hitta cykliska referenser i fader-ID-organiserat träd?

SELECT  n.*, CONNECT_BY_ROOT(id), level
FROM    elements n
START WITH
        id IN
        (
        SELECT  MIN(id)
        FROM    (
                SELECT  id, CONNECT_BY_ROOT(id) AS root
                FROM    elements
                START WITH
                        id IN
                        (
                        SELECT  id
                        FROM    elements n
                        WHERE   CONNECT_BY_ISCYCLE = 1
                        CONNECT BY NOCYCLE
                                father_id = PRIOR id
                        )
                CONNECT BY NOCYCLE
                        id = PRIOR father_id
                )
        GROUP BY
                root
        )
CONNECT BY NOCYCLE
        id = PRIOR father_id

Du kanske vill läsa den här artikeln:




  1. Summera uppslagningar i SSRS

  2. Kan jag ställa in ett standardschema för inom en lagrad procedur?

  3. Returnera sökresultat baserat på dagens datum i SQL (MySQL) del 2

  4. MySQL-användare som anges som definierare finns inte