1. OUTER JOIN
INNER JOIN이 JOIN 조건에 부합하는 행만 JOIN이 발생하는 것이라면,
OUTER JOIN은 조건에 부합하지 않는 행까지도 포함시켜 결합하는 것을 의미한다.
자주는 아니지만, 가끔 유용하게 사용될 수 있으므로 꼭 알아둘 필요는 있다.
기본 구문은 아래와 같다.
SELECT <열 목록>
FROM <첫번째 테이블 (LEFT 테이블)>
<LEFT | RIGHT | FULL> OUTER JOIN <두번째 테이블 (RIGHT 테이블)>
ON <조인될 조건>
[WHERE 검색 조건]
INNER JOIN과 유사해 보이지만, LEFT, RIGHT, FULL의 새로운 키워드들이 보인다.
2. LEFT OUTER JOIN
LEFT OUTER JOIN은 왼쪽 테이블의 것은 조건에 부합하지 않더라도 모두 결합되어야 한다는 의미이다.
즉, FROM 첫번째 테이블 LEFT OUTER JOIN 두번째 테이블이라면, 첫번째 테이블의 것은 모두 출력되어야 한다.
예제를 살펴 보자.
-- 전체 회원의 구매기록을 살펴보자.
-- 단, 구매 기록이 없는 회원도 출력되어야 한다.
-- LEFT OUTER JOIN이므로, UserTable은 모두 출력된다
SELECT U.ID, Name, GoodName, Addr
FROM UserTable U -- LEFT Table
LEFT OUTER JOIN BuyTable B -- RIGHT Table
ON U.ID = B.ID
ORDER BY U.ID
INNER JOIN시 INNER 키워드를 생략 가능했던 것처럼,
LEFT OUTER JOIN 역시 LEFT JOIN만으로 작성해도 무방하다.
위 예제의 결과는 아래와 같다. (모든 UserTable의 행이 출력되었다)
3. RIGHT OUTER JOIN
RIGHT OUTER JOIN은 오른쪽 테이블의 것은 조건에 부합하지 않더라도 모두 결합되어야 한다는 의미이다.
즉, FROM 첫번째 테이블 RIGHT OUTER JOIN 두번째 테이블이라면, 두번째 테이블의 것은 모두 출력되어야 한다.
LEFT OUTER JOIN의 예제와 동일한 결과를 얻을 수 있도록 예제를 작성해 보자.
- 전체 회원의 구매기록을 살펴보자.
-- 단, 구매 기록이 없는 회원도 출력되어야 한다.
-- RIGHT OUTER JOIN이므로, UserTable은 모두 출력된다
SELECT U.ID, Name, GoodName, Addr
FROM BuyTable B -- LEFT Table
RIGHT OUTER JOIN UserTable U -- RIGHT Table
ON B.ID = U.ID
ORDER BY U.ID
역시 RIGHT OUTER JOIN은 RIGHT JOIN만으로도 작성이 가능하다.
4. FULL OUTER JOIN
전체 조인 또는 전체 외부 조인이라고 한다.
FULL OUTER JOIN은 LEFT OUTER JOIN과 RIGHT OUTER JOIN을 합친 것이라고 생각하면 된다.
즉, 한쪽을 기준으로 조건과 일치하지 않는 것을 출력하는 것이 아니라,
양쪽 모두에 조건이 일치하지 않는 것들까지 모두 결합하는 개념이다.
따라서, 테이블들의 모든 행이 조건에 관계없이 결합된다.
5. 세 개 이상의 테이블 조인
INNER JOIN 문서의 예제를 재활용하자.
INNER JOIN 예제를 보면, 동아리에 가입하지 않은 '김제둥'은 결과에 포함되지 않았다.
이를 OUTER JOIN으로 동아리에 가입하지 않은 학생까지 출력되도록 예제를 작성해 보자.
SELECT S.Name, Addr, C.Name, RoomNo
FROM StudentTable S
-- 먼저 StudentTable이 모두 출력될 수 있도록 StdClubTable과 LEFT OUTER JOIN
LEFT OUTER JOIN StdClubTable SC
ON S.Name = SC.StdName
-- 그 결합에 다시 ClubTable을 LEFT OUTER JOIN
LEFT OUTER JOIN ClubTable C
ON SC.ClubName = C.Name
결과는 다음과 같이 동아리에 가입하지 않은 '김제둥'도 출력되었다.
이번엔 학생 기준이 아닌, 동아리를 기준으로 가입된 학생을 출력하되,
가입 학생이 하나도 없는 동아리라도 출력될 수 있도록 예제를 작성해 보자.
SELECT C.Name, RoomNo, S.Name, Addr
FROM StudentTable S
-- 먼저 StudentTable이 모두 출력될 수 있도록 StdClubTable과 LEFT OUTER JOIN
LEFT OUTER JOIN StdClubTable SC
ON S.Name = SC.StdName
-- 이후 클럽이 모두 출력될 수 있도록 ClubTable이 결합 결과를 RIGHT OUTER JOIN
RIGHT OUTER JOIN ClubTable C
ON SC.ClubName = C.Name
결과는 아래와 같다.
사실 위 예제에서 동아리에 가입하지 않은 학생의 경우 최종 목적 출력에 아무런 의미가 없으므로,
아래와 같이 작성하는 것이 더욱 깔끔하고 성능도 조금 더 낫다.
SELECT C.Name, RoomNo, S.Name, Addr
FROM StudentTable S
-- StudentTable과 StdClubTable을 INNER JOIN하여 동아리에 가입한 학생을 추출하고,
INNER JOIN StdClubTable SC
ON S.Name = SC.StdName
-- 모든 클럽이 출력될 수 있도록 위 INNER JOIN의 결합 결과를
-- ClubTable이 다시 RIGHT OUTER JOIN
RIGHT OUTER JOIN ClubTable C
ON SC.ClubName = C.Name
'DATABASE(SQL)' 카테고리의 다른 글
DB모델링실습 - 도서관리, PC제조판매 (0) | 2019.09.25 |
---|---|
DB모델링실습 - 제조판매관리시스템, 중고장터관리 (0) | 2019.09.24 |
DB모델링실습 - 제품관리, 주문배송관리 (0) | 2019.09.23 |
DB모델링실습 - 강좌, 보험회사, 학교 (0) | 2019.09.20 |
INNER JOIN (0) | 2019.08.01 |