OUTER JOIN

|

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

And