외부 조인은 왼쪽 외부 조인, 오른쪽 외부 조인, 완전 외부 조인으로 구분됩니다. 앞서 학습한 내부 조인은 조건에 맞는 레코드를 얻고, 조건에 맞지 않는 레코드는 조인 쿼리 테이블에서 제거한다. 외부 조인의 특징은 쿼리 결과가 조건을 충족하지 못할 수 있다는 것입니다.
1. 왼쪽 외부 조인
왼쪽 외부 조인은 왼쪽 테이블의 모든 레코드를 쿼리하여 조건에 맞지 않는 왼쪽 테이블의 레코드에 해당하는 오른쪽 테이블의 열 값을 표시합니다. NULL로. Left Outer Join의 키워드는 LEFT OUTER JOIN이고, 해당 SQL 문은 다음과 같습니다.
SELECT * FROM Table 1 Alias 1 LEFT OUTER JOIN Table 2 Alias 2 ON Alias 1. = 별칭 2. 열 이름
표 1은 왼쪽 테이블, 즉 메인 테이블이고, 표 2는 오른쪽 테이블입니다.
왼쪽 외부 조인을 사용하여 각 직원의 정보와 부서 정보를 쿼리합니다. 해당 쿼리 문은 다음과 같습니다. emp e 왼쪽 외부 조인 부서 d on e.deptno=d.deptno,
쿼리 결과 기준 왼쪽 테이블의 레코드가 조건을 만족하지 않는 경우 오른쪽 테이블의 컬럼 값이 null이 되는 것을 알 수 있다.
2. 오른쪽 외부 조인
오른쪽 외부 조인은 오른쪽 테이블의 모든 레코드를 쿼리하여 조건에 맞지 않는 오른쪽 테이블의 레코드에 해당하는 왼쪽 테이블의 열 값을 표시합니다. NULL로. Right Join의 키워드는 RIGHT OUTER JOIN이고, 해당 SQL 문은 다음과 같습니다.
SELECT * FROM Table 1 Alias 1 RIGHT OUTER JOIN Table 2 Alias 2 ON Alias 1. 별칭 2. 열 이름
여기서 표 1은 왼쪽 테이블이고 표 2는 오른쪽 테이블이며 메인 테이블이라고도 합니다.
오른쪽 외부 조인을 사용하여 각 부서의 정보와 해당 부서의 직원 정보를 쿼리합니다. select * from emp e right Outer Join dept d on e.deptno=d.deptno,
3 완전 외부 조인
완전 외부 조인은 왼쪽 테이블과 오른쪽 테이블에 제한이 없으며, 두 테이블에서 조건에 맞지 않는 자리는 null로 채워집니다. 완전 외부 조인의 키워드는 FULL OUTRE JOIN이며, 해당 SQL 문은 다음과 같습니다.
SELECT * FROM Table 1 Alias 1 FULL OUTER JOIN Table 2 Alias 2 ON Alias 1. = 별칭 2. 컬럼 이름
MySQL 데이터베이스는 완전 외부 조인을 지원하지 않지만 분석 관점에서 보면 완전 외부 조인은 왼쪽 외부 조인과 오른쪽 외부 조인의 결과를 결합합니다.
완전 외부 조인을 사용하여 emp 테이블과 dept 테이블의 정보 쿼리
SELECT
*
FROM
emp e LEFT OUTER JOIN dept d
ON
e.deptno= d. deptno
UNION
SELECT
*
FROM
emp e RIGHT OUTER JOIN dept d
ON
e.deptno=d.deptno
그림 1의 쿼리 -3 결과에서 조건을 만족하지 않는 두 테이블의 해당 위치는 null로 대체됩니다.
왼쪽 외부 조인 쿼리를 사용합니다. 왼쪽 테이블은 e1이므로 e2 테이블의 조건을 충족하지 않는 위치는 모두 null로 대체됩니다.