Jeśli dobrze cię zrozumiałem, chcesz wybrać tylko menedżerów.
Poniższy przykład jest oparty na schemacie Scotta.
Oto wszyscy pracownicy wraz z ich menedżerami (hierarchicznie), aby łatwiej było ich dostrzec.
SQL> select lpad(' ', (level - 1) * 2) || ename ename
2 from emp
3 start with mgr is null
4 connect by prior empno = mgr;
ENAME
------------------------------------------------------
KING -- manager
JONES -- manager
FORD -- manager
SMITH -- employee
BLAKE -- manager
ALLEN -- employee
WARD -- employee
MARTIN -- employee
TURNER -- employee
JAMES -- employee
CLARK -- manager
MILLER -- employee
12 rows selected.
SQL>
Dodatkowe WHERE
klauzula zwraca tylko menedżerów:
SQL> select lpad(' ', (level - 1) * 2) || ename ename
2 from emp
3 where empno in (select mgr from emp)
4 start with mgr is null
5 connect by prior empno = mgr;
ENAME
--------------------------------------------------------
KING
JONES
FORD
BLAKE
CLARK
SQL>
Zastępowanie co jest wybierany za pomocą SYS_CONNECT_BY_PATH
, otrzymamy inny wynik:
SQL> select sys_connect_by_path(ename, ' / ') path
2 from emp
3 where empno in (select mgr from emp)
4 start with mgr is null
5 connect by prior empno = mgr;
PATH
----------------------------------------------------
/ KING
/ KING / JONES
/ KING / JONES / FORD
/ KING / BLAKE
/ KING / CLARK
SQL>
Lub, postępując zgodnie z Twoimi krokami, samodołącz do EMP
stół, dostajemy
SQL> select m1.ename manager, m2.ename his_manager
2 from emp m1 join emp m2 on m1.mgr = m2.empno
3 where m1.empno in (select mgr from emp);
MANAGER HIS_MANAGER
---------- -------------
FORD JONES
CLARK KING
BLAKE KING
JONES KING
SQL>
Wybierz ten, który najbardziej Ci odpowiada. Wierzę, że inni członkowie zaproponują inne opcje.