웹프로그래밍

Global It Leader!!


MySql


 
 

OUTER JOIN에 대한 설명

페이지 정보

작성자 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 댓글 0건 조회 3,563회 작성일 16-11-02 19:23

본문

1. OUTER JOIN

INNER JOIN이 JOIN 조건에 부합하는 행만 JOIN이 발생하는 것이라면, 
OUTER JOIN조건에 부합하지 않는 행까지도 포함시켜 결합하는 것을 의미한다.

자주는 아니지만, 가끔 유용하게 사용될 수 있으므로 꼭 알아둘 필요는 있다.

기본 구문은 아래와 같다.

  1. SELECT <열 목록>
  2. FROM <첫번째 테이블 (LEFT 테이블)>
  3.     <LEFT | RIGHT | FULL> OUTER JOIN <두번째 테이블 (RIGHT 테이블)>
  4.                           ON <조인될 조건>
  5. [WHERE 검색 조건]

INNER JOIN과 유사해 보이지만, LEFT, RIGHT, FULL의 새로운 키워드들이 보인다.


2. LEFT OUTER JOIN

LEFT OUTER JOIN왼쪽 테이블의 것은 조건에 부합하지 않더라도 모두 결합되어야 한다는 의미이다.

즉, FROM 첫번째 테이블 LEFT OUTER JOIN 두번째 테이블이라면, 첫번째 테이블의 것은 모두 출력되어야 한다.
예제를 살펴 보자.

  1. -- 전체 회원의 구매기록을 살펴보자.
  2. -- 단, 구매 기록이 없는 회원도 출력되어야 한다.
  3.  
  4. -- LEFT OUTER JOIN이므로, UserTable은 모두 출력된다
  5.  
  6. SELECT U.ID, Name, GoodName, Addr
  7. FROM UserTable U                    -- LEFT Table    
  8.         LEFT OUTER JOIN BuyTable B  -- RIGHT Table
  9.         ON U.ID = B.ID
  10. ORDER BY U.ID

INNER JOIN시 INNER 키워드를 생략 가능했던 것처럼,
LEFT OUTER JOIN 역시 LEFT JOIN만으로 작성해도 무방하다.

위 예제의 결과는 아래와 같다. (모든 UserTable의 행이 출력되었다)

d0014632_5117ea8687b57.png


3. RIGHT OUTER JOIN

RIGHT OUTER JOIN오른쪽 테이블의 것은 조건에 부합하지 않더라도 모두 결합되어야 한다는 의미이다.

즉, FROM 첫번째 테이블 RIGHT OUTER JOIN 두번째 테이블이라면, 두번째 테이블의 것은 모두 출력되어야 한다.
LEFT OUTER JOIN의 예제와 동일한 결과를 얻을 수 있도록 예제를 작성해 보자.

  1. -- 전체 회원의 구매기록을 살펴보자.
  2. -- 단, 구매 기록이 없는 회원도 출력되어야 한다.
  3.  
  4. -- RIGHT OUTER JOIN이므로, UserTable은 모두 출력된다
  5.  
  6. SELECT U.ID, Name, GoodName, Addr
  7. FROM BuyTable B                       -- LEFT Table    
  8.         RIGHT OUTER JOIN UserTable U  -- RIGHT Table
  9.         ON B.ID = U.ID
  10. ORDER BY U.ID

역시 RIGHT OUTER JOIN은 RIGHT JOIN만으로도 작성이 가능하다.


4. FULL OUTER JOIN

전체 조인 또는 전체 외부 조인이라고 한다.
FULL OUTER JOIN은 LEFT OUTER JOIN과 RIGHT OUTER JOIN을 합친 것이라고 생각하면 된다.

즉, 한쪽을 기준으로 조건과 일치하지 않는 것을 출력하는 것이 아니라,
양쪽 모두에 조건이 일치하지 않는 것들까지 모두 결합하는 개념이다.

따라서, 테이블들의 모든 행이 조건에 관계없이 결합된다.

댓글목록

등록된 댓글이 없습니다.

전체 57
게시물 검색
MySql 목록
번호 제목 글쓴이 조회 날짜
57 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 74 05-30
56 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 567 06-30
55 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 569 06-30
54 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 597 05-25
53 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 772 02-03
52 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 859 10-21
51 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 1575 03-14
50 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 3709 08-03
49 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 2218 04-10
48 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 2272 03-26
47 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 3366 12-29
46 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 2536 11-04
45 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 3047 09-07
열람중 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 3564 11-02
43 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 4239 11-02
42 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 3893 03-28
41 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 3985 07-31
40 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 4033 09-02
39 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 3851 09-02
38 no_profile 오원장쪽지보내기 메일보내기 자기소개 아이디로 검색 전체게시물 3983 03-20