티스토리 뷰

프로그래밍

[DB] ORACLE start with, connect by

ReturnToHome 2016. 12. 24. 21:10

오라클 데이터베이스  scott유저의 emp테이블을 보면 empno와 mgr컬럼이 있습니다. 

 


mgr 컬럼의 데이터는 해당 사원의 관리자의 empno를 의미 합니다.

 


예를 들어서 아래의 데이터를 보면은..

 


  EMPNO ENAME         SAL        MGR

 ------ --------- ------- ----------

   7369     SMITH          800       7902

   7902     FORD          3000       7566



empno 7369사원의  관리자는 7902의 empno를 가진 사원이며

empno 7902사원의  관리자는 7566의 empno를 가진 사원입니다. 

 

 

이런 상위 계층과 하위계층의 관계를 오라클에서는 START WITH와 CONNECT BY를 이용해서

쉽게 가져올 수 있습니다. 

 

상품의 카테고리(대분류,중분류,소분류...)를 조회 할때 START WITH와 CONNECT BY를 이용하면 

트리 구조로 편리하게 조회 할 수 있습니다. 



게시판에서의 일반글과 답변글 과의 관계에서도 사용 할 수 있습니다



⊙ START WITH와 CONNECT BY를 이용해 데이터를 계층적인 순서로  조회할 수 있습니다. 


 

◈ START WITH 


- 계층 질의의 루트(부모행)로 사용될 행을 지정 합니다.. 

- 서브쿼리를 사용할 수도 있습니다.



◈ CONNECT BY 


- 이 절을 이용하여 계층 질의에서 상위계층(부모행)과 하위계층(자식행)의 관계를 규정 합니다. 

- 보통 PRIOR 연산자를 많이 사용 합니다.. 

- 서브쿼리를 사용할 수 없습니다.. 




◈ CONNECT BY의 실행순서는 다음과 같습니다.


- 첫째 START WITH절 

- 둘째 CONNECT BY 절

- 세째 WHERE 절 순서로 풀리게 되어있습니다.



-- 테스트를 위해서 scott유저로 접속을 합니다. 

SQLPLUS scott/tiger



예제1)상위계층과 하위 계층 관계의 순서대로 쿼리해 옴



-- LEVEL 예약어를 사용하여  depth를 표현 할 수 있습니다. 

-- 직업이 PRESIDENT을 기준으로 계층 구조로 조회합니다. 


SQL>SELECT LEVEL,empno,ename, mgr

       FROM  emp

       START WITH job = 'PRESIDENT'   -- 직업이 PRESIDENT를 기준으로

       CONNECT BY PRIOR  empno = mgr; -- 사원(empno)과 관리자(mgr)의  관계를 계층 구조로 조회

   

   LEVEL      EMPNO ENAME                       MGR

--------- ---------- -------------------- ----------

       1       7839      KING

       2       7566      JONES                      7839

       3       7788      SCOTT                     7566 

       4       7876      ADAMS                     7788 

       3       7902      FORD                       7566

       4       7369      SMITH                       7902

       2       7698      BLAKE                       7839

       3       7499      ALLEN                       7698

       3       7521      WARD                       7698

       3       7654      MARTIN                     7698

       3       7844      TURNER                     7698

       3       7900      JAMES                       7698

       2       7782      CLARK                       7839

       3       7934      MILLER                      7782



--  LEVEL컬럼은 depth를 나타냅니다. 

-- JONES의 관리자는 KING을 나타냅니다. 

--  SCOTT의 관리자는 JONES를 나타냅니다. 

--  예제와 같이 상/하의 계층 구조를 쉽게 조회 할 수 있습니다. 



예제2) 사원성명을 계층 구조로 보여 줌



SQL>SET LINESIZE 100

SQL>SET PAGESIZE 100

SQL>COL ename FORMAT A20


-- 예제1의 결과를 가지고 LPAD함수를 이용해서 ename왼쪽에 공백을 추가 했습니다. 

SQL>SELECT LPAD(' ', 4*(LEVEL-1)) || ename ename, empno, mgr, job 

      FROM emp

      START WITH job='PRESIDENT'

      CONNECT BY PRIOR empno=mgr; 


ENAME                     EMPNO        MGR JOB

-------------------- ---------- ---------- ---------

KING                        7839                   PRESIDENT

   JONES                  7566       7839      MANAGER

       SCOTT             7788       7566      ANALYST

           ADAMS         7876       7788      CLERK

       FORD               7902       7566      ANALYST

           SMITH          7369       7902      CLERK

   BLAKE                  7698       7839      MANAGER

       ALLEN               7499       7698     SALESMAN

       WARD               7521       7698     SALESMAN

       MARTIN             7654       7698     SALESMAN

       TURNER            7844       7698     SALESMAN

       JAMES              7900       7698     CLERK

   CLARK                  7782       7839     MANAGER

       MILLER              7934       7782     CLERK



예제3) 레벨이 2까지만 쿼리해서 가져오는 예제

  

SQL>SELECT LPAD(' ', 4*(LEVEL-1)) || ename ename, empno, mgr, job 

       FROM emp

       START WITH job='PRESIDENT'

      CONNECT BY PRIOR empno=mgr 

       AND LEVEL <=2 ; 

   

ENAME                     EMPNO        MGR JOB

-------------------- ---------- ---------- ---------

KING                        7839                   PRESIDENT

   JONES                  7566       7839      MANAGER

   BLAKE                  7698       7839      MANAGER

   CLARK                  7782       7839      MANAGER  


예제4) 각 label별로 급여의 합과 인원수를 구하는 예제


SQL> SELECT LEVEL, SUM(sal) total,COUNT(empno) cnt

       FROM emp

       START WITH job='PRESIDENT' 

       CONNECT BY PRIOR empno=mgr      

       GROUP BY LEVEL 

       ORDER BY LEVEL; 


    LEVEL      TOTAL        CNT

---------- ---------- ----------

        1       5000          1

        2       8275          3

        3      13850          8

        4       1900          2

댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함