Supponiamo di avere tabelle seguenticonnettersi in Oracle SQL
create table Employee(
2 EMPNO NUMBER(3),
3 ENAME VARCHAR2(15 BYTE),
4 HIREDATE DATE,
5 ORIG_SALARY NUMBER(6),
6 CURR_SALARY NUMBER(6),
7 REGION VARCHAR2(1 BYTE),
8 MANAGER_ID NUMBER(3)
9 )
e
create table job (
2 EMPNO NUMBER(3),
3 jobtitle VARCHAR2(20 BYTE)
4 )
5/
Sono interessato a ciò che la domanda sotto fa
SELECT empno, manager_id, ename
2 FROM employee
3 START WITH empno = 1
4 CONNECT BY PRIOR empno = manager_id;
Come ho capito questo codice seleziona empno
, manager_id
, ename
dal dipendente, inizia la selezione f rom questa riga in cui empno=1
, ma non riusciva a capire che cosa questa linea fa:
CONNECT BY PRIOR empno = manager_id;
questo è lo stesso:
where empno=manager_id?
[Docs] (http://docs.oracle.com/cd/B19306_01/server.102/b14200/queries003.htm) – turbanoff