Mam tabeli tak:Jak analizować sąsiednią listę w Oracle 10g?
+---------+--------+
| EMP_ID | MGR_iD |
+---------+--------+
| 1 | 1 |
| 2 | 1 |
| 3 | 1 |
| 4 | 2 |
| 5 | 2 |
| 6 | 2 |
| 7 | 3 |
| 8 | 5 |
| 9 | 7 |
| 10 | 5 |
| 11 | 7 |
| 12 | 9 |
| 13 | 9 |
| 14 | 9 |
+---------+--------+
Próbuję analizować ten sąsiedniej liście do wytworzenia następujący zestaw wyników:
| EMP_ID | MGR_ID | LV | LEVEL1 | LEVEL2 | LEVEL3 | LEVEL4 | LEVEL5 |
---------------------------------------------------------------------
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 2 | 1 | 2 | 1 | 2 | 2 | 2 | 2 |
| 3 | 1 | 2 | 1 | 3 | 3 | 3 | 3 |
| 4 | 2 | 3 | 1 | 2 | 4 | 4 | 4 |
| 5 | 2 | 3 | 1 | 2 | 5 | 5 | 5 |
| 6 | 2 | 3 | 1 | 2 | 6 | 6 | 6 |
| 7 | 3 | 3 | 1 | 3 | 7 | 7 | 7 |
| 8 | 5 | 4 | 1 | 2 | 5 | 8 | 8 |
| 9 | 7 | 4 | 1 | 3 | 7 | 9 | 9 |
| 10 | 5 | 4 | 1 | 2 | 5 | 10 | 10 |
| 11 | 7 | 4 | 1 | 3 | 7 | 11 | 11 |
| 12 | 9 | 5 | 1 | 3 | 7 | 9 | 12 |
| 13 | 9 | 5 | 1 | 3 | 7 | 9 | 13 |
| 14 | 9 | 5 | 1 | 3 | 7 | 9 | 14 |
Oto co udało mi się dostać do tej pory:
create table PC (
EMP_ID NUMBER NULL,
MGR_ID NUMBER NULL
);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (1.0, 1.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (2.0, 1.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (3.0, 1.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (4.0, 2.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (5.0, 2.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (6.0, 2.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (7.0, 3.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (8.0, 5.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (9.0, 7.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (10.0, 5.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (11.0, 7.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (12.0, 9.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (13.0, 9.0);
INSERT INTO PC (EMP_ID, MGR_ID)
VALUES (14.0, 9.0);
a zapytanie:
WITH PERSON_HIER AS
(
SELECT 1 as level1,
CAST(NULL AS NUMBER) as level2,
CAST(NULL AS NUMBER) as level3,
CAST(NULL AS NUMBER) as level4,
CAST(NULL AS NUMBER) as level5
FROM PC
WHERE EMP_ID = 1 AND MGR_ID = 1
UNION ALL
SELECT L1.EMP_ID AS LEVEL1,
L2.EMP_ID AS LEVEL2,
L3.EMP_ID AS LEVEL3,
L4.EMP_ID AS LEVEL4,
L5.EMP_ID AS LEVEL5
FROM PC L1
LEFT OUTER JOIN PC L2 ON (L1.EMP_ID = L2.MGR_ID AND L2.EMP_ID != L1.EMP_ID)
LEFT OUTER JOIN PC L3 ON (L2.EMP_ID = L3.MGR_ID)
LEFT OUTER JOIN PC L4 ON (L3.EMP_ID = L4.MGR_ID)
LEFT OUTER JOIN PC L5 ON (L4.EMP_ID = L5.MGR_ID)
WHERE L1.MGR_ID = L1.EMP_ID
)
SELECT level1,
coalesce(level2, level1) AS LEVEL2,
coalesce(level3, level2, level1) AS LEVEL3,
coalesce(level4, level3, level2, level1) AS LEVEL4,
coalesce(level5, level4, level3, level2, level1) AS LEVEL5
FROM PERSON_HIER
order by level5
Używam Oracle 10g więc rekurencyjne CTE lub hierarchicznych zapytań nie jest możliwe w Oracle 10g
Co się stanie, jeśli jest więcej niż 5 poziomów? – Ben
Chcę tylko wydrukować pierwszych 5 poziomów ... – jrara
co masz na myśli, że zapytania hierarchiczne nie są możliwe w 10g? 'connect by' jest dostępne od wieków, dlaczego trzymać się CTE? –