오라클 계층 구조의 조회(Hierarchical Queries)

 

오라클 데이터베이스 scott유저의 emp테이블을 보면 empno와 mgr컬럼이 있습니다.
mgr 컬럼의 데이터는 해당 사원의 관리자의 empno를 의미 합니다.
예를 들어서 아래의 데이터를 보면은..

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 절 순서로 풀리게 되어있습니다.

예제1)상위계층과 하위 계층 관계의 순서대로 쿼리해 옴
LEVEL 예약어를 사용하여 depth를 표현 할 수 있습니다.
직업이 PRESIDENT을 기준으로 계층 구조로 조회합니다.

LEVEL컬럼은 depth를 나타냅니다.
JONES의 관리자는 KING을 나타냅니다.
SCOTT의 관리자는 JONES를 나타냅니다.
예제와 같이 상/하의 계층 구조를 쉽게 조회 할 수 있습니다.

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

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

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

◈ 데이터가 많아질 경우….
– 첫째로 풀리는 START WITH job=’PRESIDENT’ job 컬럼에 index가 생성되어 있지 않는다면 속도를 보장할 수 없습니다.
– 그리고 둘째로 풀리는 CONNECT BY PRIOR empno = mgr 역시 PRIOR 쪽의 컬럼값이 상수가 되기 때문에 MGR컬럼에 index를 생성하여야 CONNECT BY의 속도를 보장할 수 있습니다.
– 계층구조를 CONNECT BY, START WITH로 풀면 부분범위 처리가 불가능하고 Desc으로 표현하기가 어렵습니다.

 

This entry was posted in Database and tagged , , , , . Bookmark the permalink.

댓글 남기기