sql >> Base de Datos >  >> RDS >> Oracle

Conexión SQL por muchas filas

Actualizar

Después de ver su actualización, solo tiene que soltar COMENZAR CON.

Finalizar actualización

CONECTAR_POR_RAÍZ es lo que buscas

Esta declaración

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

Salidas

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

Agregar SUMAS y GRUPOS es bastante fácil