출처 - http://egloos.zum.com/wingh/v/4082857
◈ Out(외부) Join
- equijoin 문장들의 한가지 제약점은 그것들이 조인을 생성하려 하는 두 개의 테이블의 두 개
컬럼에서 공통된 값이 없다면 테이블로부터 테이터를 Return하지 않는 다는 것입니다.
- 정상적으로 조인 조건을 만족하지 못하는 행들을 보기위해 outer join을 사용합니다.
Outer join 연산자 "( + )"입니다.
-조인시킬 값이 없는 조인측에 "( + )"를 위치 시킵니다.
- Outer join 연산자는 표현식의 한 편에만 올 수 있습니다.
|
Oracle9i 부터는 ANSI/ISO SQL표준인 LEFT OUTER JOIN , RIGHT OUTER JOIN, FULL OUTER JOIN를 지원 합니다. |
☞ LEFT OUTER JOIN 왼쪽 테이블에 조인시킬 컬럽의 값이 없는 경우 사용합니다. SQL>SELECT DISTINCT(e.deptno), d.deptno FROM dept d LEFT OUTER JOIN emp e ON d.deptno = e.deptno; ☞ RIGHT OUTER JOIN - 오른쪽에 테이블에 조인시킬 컬럽의 값이 없는 경우 사용합니다. SQL>SELECT DISTINCT(a.deptno), b.deptno FROM emp a RIGHT OUTER JOIN dept b ON a.deptno = b.deptno; ☞ FULL OUTER JOIN 양쪽 테이블에 다 outer join을 거는것을 TWO-WAY OUTER JOIN 또는 FULL OUTER JOIN이라 합니다. SQL>SELECT DISTINCT(a.deptno), b.deptno FROM emp a FULL OUTER JOIN dept b ON a.deptno = b.deptno; -- 위 세 문장의 결과는 아래와 같습니다. DEPTNO DEPTNO ---------- ---------- 10 10 20 20 30 30 40 LEFT OUTER JOIN과 RIGHT OUTER JOIN의 테이블 순서를 바꾸어 가면서 테스트를 하시면 쉽게 이해를 하실 수 있습니다. |
출처 : 오라클 클럽
'IT > DB' 카테고리의 다른 글
[Oracle] pro*c 란 - 초보자를 위한 개념 설명 (10) | 2016.05.13 |
---|---|
[DB] order by 1의 뜻 (0) | 2016.04.25 |
[DB] oracle NVL함수 (0) | 2016.04.25 |
[Oracle] Grouping(), ROLLUP, CUBE Study 정리 (0) | 2016.04.22 |
-펌-[DB]SQL / MySQL 서브쿼리(SubQuery) (0) | 2016.04.06 |