Oracle
 sql >> Base de données >  >> RDS >> Oracle

Connexion SQL par pour plusieurs lignes

Mettre à jour

Après avoir vu votre mise à jour, il vous suffit de déposer le COMMENCER PAR.

Finir la mise à jour

CONNECT_BY_ROOT est ce que vous cherchez

Cette déclaration

SELECT distinct RootBoss, Person FROM (
with employee  as 
(
  Select 1 person , null boss from Dual
  UNION Select 2 , 1 from dual
  UNION Select 3 , 2 from dual
)
SELECT CONNECT_BY_ROOT boss RootBoss, person
FROM employee connect_by

  connect by prior person = boss
  ORDER BY person

  ) t
WHERE ROOTBOSS is not null
ORDER BY
RootBoss, Person

Sorties

ROOTBOSS               PERSON                 
---------------------- ---------------------- 
1                      2                      
1                      3                      
2                      3        

L'ajout de SOMMES et de GROUPES est assez simple