일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 코딩
- 해외여행
- 파티룸
- MBTI
- 착한코딩
- 옥길그릭요거트
- 존경하는위인
- 보드게임점수계산
- 스컬킹점수계산
- 광명파티룸
- 일
- 서울파티룸
- 옥길동파티룸
- 보드게임점수
- 옥길파티룸
- mysql
- 구로파티룸
- 옥길요거트
- 그릭요거트
- 취미
- 부천파티룸
- 개발자
- 스컬킹점수
- 스컬킹
- 웹개발
- 가장존경하는인물
- 부천공간대여
- 옥길동요거트
- 휴식
- 스페이스우일
- Today
- Total
SIMPLE & UNIQUE
오라클 START WITH ~ CONNECT BY PRIOR 본문
START WITH ~ CONNECT BY PRIOR
- 예문
SELECT *
FROM employee A
CONNECT BY PRIOR A.emp_id = A.manager_emp_id
AND A.emp_id <> '1002'
START WITH A.emp_id = '1001'
AND EX_YN = 'Y'
- START WITH는 처음 시작할 조건을 의미
즉, emp_id='1001' 이면서 ex_yn='Y'인 로우부터 출발한다. - CONNECT BY는 위의 데이터와 연결된 로우를 반복하여 찾는다.
- EMP_ID ('1001')를 manager_emp_id 로 갖는 로우를 찾는다.
CONNECT BY와 START WITH의 순서는 의미없다.
CONNECT BY 다음의 AND 는 순환 관계를 푼다.
AND 조건을 만족하지 않으면 그 다음 레벨은 더 이상 진행하지 않음을 의미.
SELECT *
FROM employee A
CONNECT BY PRIOR A.emp_id = A.manager_emp_id
AND A.emp_id <> '1002'
START WITH A.emp_id = '1001'
AND EX_YN = 'Y'
; -- '1001'의 하위인 '1002'가 AND 조건에 맞지 않으므로 '1002'의 하위인 '1007','1009'는 조회되지 않는다.
결과
EMP_ID MANAGER_EMP_ID EX_YN
1001 1000 Y
1003 1001 Y
1010 1003 Y
1008 1001 Y
FROM 절 다음의 WHERE는 순환구조를 모두 전개 한 후에 조건에 해당하는 로우만 츨력
SELECT *
FROM employee A
WHERE A.emp_id <> '1002'
CONNECT BY PRIOR A.emp_id = A.manager_emp_id
START WITH A.emp_id = '1001'
AND EX_YN = 'Y'
; -- '1002'의 하위인 '1007','1009'를 전개 한 후 emp_id='1002'만 걸러냄.
결과
EMP_ID MANAGER_EMP_ID EX_YN
1001 1000 Y
1007 1002 Y
1009 1002 Y
1003 1001 Y
1010 1003 Y
1008 1001 Y
출처 : http://c36wn.egloos.com/4350031
출처: http://joke00.tistory.com/89 [Smile virus]