Oracle
 sql >> база данни >  >> RDS >> Oracle

SQL SELECT за намиране на циклични препратки в организирано по баща ID дърво?

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

Може да искате да прочетете тази статия:




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PL/SQL на SquirreL SQL клиент 3.7.1

  2. pivot не работи при използване на вложен избор в SQL

  3. Защо Hibernate превключи да използва LONG над CLOB?

  4. Бързо опресняване на материализиран изглед с клауза HAVING?

  5. Предайте SELECT STATEMENT като IN параметър за процедура и изпълнение в Oracle