sql 독학 강의 # outer join SQL 15편 -sTricky
sql 독학 강의 # outer join SQL 15편 -sTricky
컨텐츠 index 0. outer join의 정의 1. outer join 사용 예제 2. outer join SQL 작성방법 |
안녕하세요.
오늘은 지난 join 관련 공부하던것과 이어서 outer join에 관해서 배워 보도록 하겠습니다.
## 전편 강의 보러 가기 ##
2020/04/27 - [Database/sql 강의] - sql 독학 강의 # 비등가 join with ansi SQL 14편 -sTricky
0. outer join의 정의
outer join은 RDBMS에서 join을 할 때 inner join을 빼면 가장 많이 사용하는 join 기법입니다.
inner join의 경우 A 와 B 두 테이블을 join 할시에 양쪽에 key값을 기준으로 모두 존재하는 데이터만 출력이 되지만, outer join은 한쪽을 기준으로 하여 다른 쪽에 key값이 일치하는 게 없더라도 모두 출력을 하는 join 기법입니다.
outer join의 종류에는 left outer join, right outer join, full outer join이 있는데 mysql에서는 full outer join을 지원하지 않고 있습니다.
left outer join과 right outer join은 어떤 방식이 다르다기 보단 왼쪽과 오른쪽 어디다가 기준을 둘 것이냐에 따라 다릅니다. 사용방법은 같다고 볼 수 있습니다.
mysql에서는 full outer join이 필요할 때는 union으로 우회적으로 사용할 수 있습니다.
## full outer join 을 union all로 구현하기##
select *
from A full outer join B
on A.a = B.b;
select *
from A left outer join B
on A.a = B.b
union
select *
from B left outer join A
on A.a = B.b;
필요시에 꼭 써야 하는 outer join이지만 필요 없을 땐 쓰지 않아야 합니다. outer join은 모든 데이터를 다 가지고 올 때 full scan을 하기 때문에 DB에 무리를 가할 수 있기 때문입니다.
적절할 때 알맞게 사용하시길 바랍니다.
outer join을 하기 테스트하기 위해서 기존 class.student 테이블에 일부 데이터를 좀 더 추가하겠습니다.
INSERT INTO class.student (student_id, major_id, bl_prfs_id, name, tel) VALUES (1031, 9901, null, '신채령', '01044755564');
INSERT INTO class.student (student_id, major_id, bl_prfs_id, name, tel) VALUES (1032, 9902, null, '이만도', '01022287777');
INSERT INTO class.student (student_id, major_id, bl_prfs_id, name, tel) VALUES (1033, 9903, null, '박만호', '01099972253');
INSERT INTO class.student (student_id, major_id, bl_prfs_id, name, tel) VALUES (1034, 9904, null, '최이강', '01029386577');
INSERT INTO class.student (student_id, major_id, bl_prfs_id, name, tel) VALUES (1035, 9905, null, '강이민', '01033334444');
INSERT INTO class.student (student_id, major_id, bl_prfs_id, name, tel) VALUES (1036, 9901, null, '민형도', '01099973331');
INSERT INTO class.student (student_id, major_id, bl_prfs_id, name, tel) VALUES (1037, 9902, null, '도지란', '01055567774');
※원본 데이터가 필요하신 분은 아래 링크로 가셔서 테이블을 생성하고 데이터를 insert 하시기 바랍니다.
https://stricky.tistory.com/243?category=1108324
위 데이터를 모두 추가하셨으면 다시 진행하겠습니다.
1. outer join 사용 예제
아래와 같이 student, professor 테이블이 각각 있을 때 그림에서 보면 student 테이블에 파란색 박스로 표시된 칼럼이 담당 교수 ID인데, 일부 담당 교수 ID가 없는 학생이 빨간 박스로 표시되어 있습니다.
이런 경우를 아직 담당교수 배정이 안된 학생이라고 가정한다면 두 테이블을 일반 inner join으로 join 한다면 전체 학생에서 아직 담당 교수가 배정되지 않은 학생들은 빠지게 됩니다.
이런 누락 없이 데이터를 모두 보고자 할 때 outer join을 쓰게 됩니다.
위 두 테이블을 left outer join 하면 아래와 같이 결과가 나오게 됩니다.
파란색 상자 안의 두 칼럼은 student 테이블에서, 노란 상자 안의 두 컬럼은 professor 테이블에서 가지고 온 데이터를 student 테이블의 bl_prfs_id와 professor 테이블의 prfs_id 두 칼럼을 키로 연결하여 left outer join을 한 건데,
결과를 보시면 아시겠지만, 아래 30번째 행부터는 오른쪽 professor 테이블에 데이터가 없습니다.
물론 좌측의 student 테이블에 더 bl_profs_id는 31번 하아부터 데이터가 null로 표시되어 있지만 students 테이블의 name 칼럼에는 데이터가 표시되고 있으니, 데이터가 있다고 봐야겠죠.
"한지호"라는 학생은 bl_prfs_id에 값이 있지만, 연결이 되지 않아 professor 테이블 데이터가 null로 표시되어 있습니다. "한지호" 학생은 bl_prfs_id에 저장된 id 값이 교수 테이블에 존재하지 않는 것을 의미하고, 나머지 "신 채령"부터 "도지란" 까지는 아예 bl_prfs_id 값이 없기 때문에 professor 테이블과 연결이 되지 않은 것입니다.
이렇게 연결되지 않은 데이터까지 left outer join을 이용해서 출력해낼 수 있습니다.
2. outer join SQL 작성방법
오라클의 경우는 (+)라는 기호를 이용해서 오 라클식(?) SQL로 작성을 할 수 있지만 mysql은 outer join의 경우 ANSI SQL 형태로 작성을 해야 합니다.
그 작성법은 아래와 같습니다.
select s.name, s.bl_prfs_id, p.name, p.prfs_id
from class.student s
left outer join class.professor p
on s.bl_prfs_id = p.prfs_id;
이전에 함께 공부했던 inner join의 ANSI SQL 작성 방법과 똑같다고 볼 수 있습니다.
여러분들께서는 left를 right로도 바꿔 보시고, 테이블 칼럼 순서도 바꿔보시면서 연습을 해보시면 될 것 같습니다. 학과 테이블과도 outer join을 작성하셔서 실습을 직접 많이 해보시길 바랍니다.
오늘 함께 공부한 outer join과 관련해서 궁금증은 언제든지 댓글로 문의하시기 바랍니다.
## 다음 강의 보러 가기 ##
2020/05/11 - [Database/sql 강의] - sql 독학 강의 # sub query 서브쿼리 16편 -sTricky
감사합니다!
오늘도 좋은 하루 보내시길 바랍니다!!