OUTER JOIN에 대한 설명
페이지 정보
작성자 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 댓글 0건 조회 3,563회 작성일 16-11-02 19:23본문
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을 합친 것이라고 생각하면 된다.
즉, 한쪽을 기준으로 조건과 일치하지 않는 것을 출력하는 것이 아니라,
양쪽 모두에 조건이 일치하지 않는 것들까지 모두 결합하는 개념이다.
따라서, 테이블들의 모든 행이 조건에 관계없이 결합된다.
댓글목록
등록된 댓글이 없습니다.