sql >> Databáze >  >> RDS >> Oracle

Oracle SQ Identify Sourozence prostřednictvím sourozenců

Není jasné, zda jsou vztahy reflexivní (tj. pokud B je "sourozenec" A pak A je "sourozenec" B ), protože máte nějaké duplicitní řádky s obrácenými vztahy ve vašich datech a některé, kde tato vlastnost není zřejmá.

Za předpokladu, že vaše vztahy nejsou reflexivní, pak:

SQL Fiddle

Nastavení schématu Oracle 11g R2 :

CREATE TABLE A ( ID, SIBS ) AS
SELECT 'A', 'B' FROM DUAL UNION ALL
SELECT 'A', 'C' FROM DUAL UNION ALL
SELECT 'B', 'A' FROM DUAL UNION ALL
SELECT 'C', 'A' FROM DUAL UNION ALL
SELECT 'C', 'D' FROM DUAL UNION ALL
SELECT 'D', 'C' FROM DUAL UNION ALL
SELECT 'E', 'F' FROM DUAL UNION ALL
SELECT 'F', 'G' FROM DUAL UNION ALL
SELECT 'G', 'H' FROM DUAL;

Dotaz 1 :

SELECT DISTINCT
       CONNECT_BY_ROOT( ID ) AS ID,
       SIBS
FROM   A
WHERE  CONNECT_BY_ROOT( ID ) <> SIBS
CONNECT BY NOCYCLE
       PRIOR SIBS = ID
ORDER BY ID, SIBS

Výsledky :

| ID | SIBS |
|----|------|
|  A |    B |
|  A |    C |
|  A |    D |
|  B |    A |
|  B |    C |
|  B |    D |
|  C |    A |
|  C |    B |
|  C |    D |
|  D |    A |
|  D |    B |
|  D |    C |
|  E |    F |
|  E |    G |
|  E |    H |
|  F |    G |
|  F |    H |
|  G |    H |

Dotaz 2 :Pokud jsou reflexivní, můžete použít UNION [ALL] duplikujte tabulku se vztahy v opačném směru a poté použijte předchozí techniku:

SELECT DISTINCT
       CONNECT_BY_ROOT( ID ) AS ID,
       SIBS
FROM   (
  SELECT ID, SIBS FROM A
  UNION
  SELECT SIBS, ID FROM A
)
WHERE  CONNECT_BY_ROOT( ID ) <> SIBS
CONNECT BY NOCYCLE
       PRIOR SIBS = ID
ORDER BY ID, SIBS

Výsledky :

| ID | SIBS |
|----|------|
|  A |    B |
|  A |    C |
|  A |    D |
|  B |    A |
|  B |    C |
|  B |    D |
|  C |    A |
|  C |    B |
|  C |    D |
|  D |    A |
|  D |    B |
|  D |    C |
|  E |    F |
|  E |    G |
|  E |    H |
|  F |    E |
|  F |    G |
|  F |    H |
|  G |    E |
|  G |    F |
|  G |    H |
|  H |    E |
|  H |    F |
|  H |    G |


  1. PHP/MySQL – zahrnout množná čísla, ale vyloučit singuláry

  2. Jak porovnat hodnoty Null v MySQL

  3. Seskupte výsledky mysql podle kategorie a zobrazte je do skupin pod každou kategorií

  4. výjimka hodnoty null při vstupu do databáze