일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
- 프로그래머스 #mysql #알고리즘 #어린 동물 찾기 #코린이 #개발자 #study
- 코린이 #개발자 #study
- 프로그래머스 #한 해에 잡은 물고기 수 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #알고리즘 #이름이 있는 동물의 아이디 #코린이 #개발자 #study
- 백준 #
- 프로그래머스 #python 개발자 찾기 #알고리즘 #mysql #코린이 #개발자 #study
- 프로그래머스 #아픈 동물 찾기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #알고리즘 #mysql #
- 백준 #일곱 난쟁이 #2309 #자바 #java #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #과일로 만든 아이스크림 고르기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #가장 큰 물고기 10마리 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #알고리즘 #mysql #인기있는 아이스크림 #코린이 #개발자 #study
- 프로그래머스 #나이 정보가 없는 회원 수 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 백준 #다이얼 #5622 #알고리즘 #자바 #java #코린이 #개발자 #study
- 프로그래머스 #조건에 맞는 회원수 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 특정 옵션이 포함된 자동차 리스트 구하기 #코린이 #개발자 #study
- 백준 #네 번째 점 #3009 #자바 #java #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #동명 동물 수 찾기 #mysql #데이터베이스 #db #코린이 #개발자 #알고리즘
- 프로그래머스 #mysql #동명 동물 수 찾기 #알고리즘 #코린이 #개발자
- 프로그래머스 #잡은 물고기 중 가장 큰 물고기의 길이 구하기 #알고리즘 #mysql #코린이 #개발자 #study
- 프로그래머스 #mysql #역순 정렬하기 #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #잡은 물고기의 평균 길이 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #12세 이하인 여자 환자 목록 출력하기 #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #모음 제거 #알고리즘 #자바 #java #코린이 #개발자 #study
- 백준 #4153 #직각삼각형 #알고리즘 #자바 #java #코린이 #개발자 #study
- mysql #min() #max() #최소값 #최대값 #코린이 #개발자 #study
- 프로그래머스 #mysql #경기도에 위치한 식품창고 목록 출력하기 #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #알고리즘 #자동차 대여 기록에서 장기/단기 대여 구분하기 #코린이 #개발자 #study
- 프로그래머스 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #흉부외과 또는 일반외과 의사 목록 출력하기 #알고리즘 #코린이 #개발자 #study
- Today
- Total
luke
[MySQL] - JOIN(OUTTER JOIN) (LEFT JOIN, RIGHT JOIN, FULL JOIN) 본문
[MySQL] - JOIN(OUTTER JOIN) (LEFT JOIN, RIGHT JOIN, FULL JOIN)
luke-king 2024. 5. 11. 19:38
[MySQL] - JOIN(OUTTER JOIN) (LEFT JOIN, RIGHT JOIN, FULL JOIN)
JOIN 이란?
- 조인은 두 개의 테이블을 서로 묶어서 하나의 결과를 만들어내는 것을 말한다.
- INNER JOIN(내부 조인) : 두 테이블을 조인할 때, 두 테이블에 모두 지정한 열의 데이터가 있어야 한다.
- OUTER JOIN(외부 조인) : 두 테이블을 조인할 때, 1개의 테이블에만 데이터가 있어도 결과가 나온다.
- CROSS JOIN(상호 조인) : 한쪽 테이블의 모든 행과 다른 쪽 테이블의 모든 행을 조인하는 기능이다.
- SELF JOIN(자체 조인) : 자신이 자신과 조인한다는 의미로, 1개의 테이블을 사용한다.
이렇게 총 4가지의 종류 JOIN이 있다.
이번 시간에는 OUTER JOIN (내부 조인)에 대해 정리해보려고 한다.
OUTTER JOIN(외부 조인)
OUTER JOIN은 위 그림과 같이 합집합, 차집합 이 떠오를 것이다.
OUTER JOIN 또한 INNER JOIN과 같이 두 테이블의 정보를 가지고 온다.
하지만 INNER JOIN과 다른 점은
1. 두 테이블 간의 교집합이 되는 데이터뿐만 아니라 해당되지 않는 값까지 가져온다.
2. 드라이빙 테이블(처음으로 가져오는 기준이 되는 테이블)이 필요하다.
그럼 LFT(OUTER) JOIN 부터 보겠다.
LEFT(OUTER) JOIN
<a_table>
<b_table>
위 두개의 a, b 테이블이 있다 각각의 칼럼에 값이 있는 것을 확인할 수 있다.
LEFT JOIN은 기준 테이블을 왼쪽에 두고, OUTER JOIN을 수행하는 것이다.
그럼 쿼리문 작성 한 뒤 결과값이 어떻게 나오는지 보겠다.
<쿼리문>
select * from a_table
left join b_table
on a_table.id = b_table.id;
(쿼리문 작성 시 OUTER는 생략할 수 있다.)
<결과>
결과를 보면 a_table을 기준으로 설정해 기준 테이블이다. 이 기준 테이블에 연결고리인 컬럼 id를 가지고
b_table이 붙는다. 생각해 보면 INNER JOIN 했을 때와 비슷하다. 하지만 INNER JOIN을 했을 때는 컬럼id 값이 일치한 값들만 나왔는데 지금은 모든 값들이 나온 걸 확인할 수 있다.
결과 사진을 보면 a_table이 기준 테이블이므로 b_table과 같지 않은 값들 또는 없는 값들은 null값으로 나온다.
RIGHT(OUTER) JOIN
이번에는 RIGHT(OUTER)JOIN 에 대해 알아보겠다.
RIGHT(OUTER)JOIN은 LEFT(OUTER)JOIN 과 같지만 기준 테이블만 다르다고 생각하면 된다.
즉 기준 테이블을 오른쪽에 두는 것이다.
그럼 쿼리문 작성 한 뒤 결과값이 어떻게 나오는지 보겠다.
<쿼리문>
select * from a_table
right join b_table
on a_table.id = b_table.id;
(쿼리문 작성 시 OUTER는 생략할 수 있다.)
<결과>
결과는 위 LEFT(OUTER)JOIN과 다르게 a_table의 6,7번 값이 나오지 않고 5번까지 나온 걸 확인할 수 있다.
왜 그런 걸까? 이유는 간단하다 기준테이블을 오른쪽에 있는 b_table이기 때문에 a_table과 다르게 id값이 5까지 있으므로
총 5개를 출력한다.
FULL(OUTER) JOIN
이번엔 FULL(OUTER)JOIN 에 대해 알아보겠다.
FULL(OUTER)JOIN은 그림과 같이 LEFT, RIGHT 모두 합한 결과를 보여주는 거라 생각하면 된다.
그럼 쿼리문 작성 한 뒤 결과값이 어떻게 나오는지 보겠다.
<쿼리문>
select * from a_table
left join b_table
on a_table.id = b_table.id
union
select * from a_table
right join b_table
on a_table.id = b_table.id;
(쿼리문 작성 시 OUTER는 생략할 수 있다.)
<결과>
결과 사진을 보면 a_table, b_table의 값들이 모두 나온 걸 확인할 수 있다.
하지만 필자는 MySQL을 UNION을 사용했다. FULL(OUTER)JOIN과 다르지 않다. 다만 MySQL에서 FULL(OUTER)JOIN 을 지원하지 않아 UNION을 사용해야 한다.
(공부한 내용들을 정리하며 글을 써봤지만 테이블들의 값들을 조금 더 쉽게 나타낼 수 있었으면 좋았을 텐데 그러지 못해 아쉽다... 이 글을 보고 헷갈리셨다면 죄송하고 궁금한 게 있으면 댓글 남겨주세요!)
'DB > MySQL' 카테고리의 다른 글
[MySQL] - SELECT, WHERE 사용 (0) | 2024.05.15 |
---|---|
[MySQL] - SQL 분류 (DML, DDL, DCL, TCL) (0) | 2024.05.14 |
[MySQL] - JOIN (INNER JOIN) (0) | 2024.05.10 |
[SQL] - WHERE (조건,다중 조건) (or, and, not) (2) | 2024.04.18 |
[SQL] - ALTER TABLE 원하는 특정 위치에 컬럼 추가 (0) | 2024.03.27 |