BackEnd/DataBase
[DB] Join(조인) 정리하기
Wonol
2022. 5. 7. 16:32
반응형
1. Join(조인) 이란?
- 한 데이터베이스 내의 여러 테이블의 레코드를 조합하여 하나의 열로 표현한 것
- 즉, 둘 이상의 테이블을 연결해서 데이터를 검색하는 방법
- 테이블로서 저장되거나, 그 자체로 이용할 수 있는 결과 셋을 만들어 낸다.
- 아래 그림은 조인을 쉽게 이해하기 위한 그림이다.
- Join의 종류
- INNER JOIN : 내부조인(교집합)
- LEFT/RIGHT JOIN : 부분집합
- OUTER JOIN : 외부조인(합집합)
2. DB에서의 조인 필요성
- 관계형 데이터베이스의 구조적 특징으로 정규화를 수행하면 의미 있는 데이터의 집합으로 테이블이 구성되고, 각 테이블끼리는 관계(Relationship)를 가진다.
- 이와 같은 특징으로 관계형 데이터베이스는 저장 공간의 효율성과 확장성이 향상된다.
- 서로 관계있는 데이터가 여러 테이블로 나뉘어 저장되므로, 각 테이블에 저장된 데이터를 효과적으로 검색이 가능하다.
3. Join(조인)의 종류
- 아래 그림은 조인의 종류를 설명하기 위한 샘플 데이터 이다.
- 내부 조인(Inner Join)
- 여러 어플리케이션에서 사용되는 가증 흔한 결합 방식
- 공통적인 부분만 SELECT
- 조인 구문에 기반한 2개의 테이블(A, B)의 컬럼 값을 결합함으로써 새로운 결과 테이블을 생성
- 명시적 조인 표현(explicit)
- join 키워드와 함께 on 키워드를 사용
SELECT *
FROM STUDENT_TABLE
INNER JOIN DEPARTMENT_TABLE
ON STUDENT_TABLE.DEPARTMENT_ID = DEPARTMENT_TABLE.DEPARTMENT_ID;
- 암시적 조인 표현(implicit)
- select 구문의 from 절에서 테이블을 분리하는 컴마(,)를 사용
SELECT *
FROM STUDENT_TABLE, DEPARTMENT_TABLE
WHERE STUDENT_TABLE.DEPARTMENT_ID = DEPARTMENT_TABLE.DEPARTMENT_ID;
- 결과
- 외부 조인(Outer Join)
- 조인 대상 테이블에서 특정 테이블의 데이터가 모두 필요한 상황에서 외부 조인을 활용하여 효과적으로 결과 집합을 생성
- 두 테이블이 가지고 있는 전체 부분 SELECT
- 왼쪽 외부 조인(LEFT OUTER JOIN)
- 우측 테이블에 조인할 컬럼의 값이 없는 경우 사용
- 좌측 테이블의 모든 데이터를 포함하는 결과 집합을 생성
- 공통적인 부분 + LEFT 테이블에 있는 데이터만 SELECT
SELECT *
FROM STUDENT_TABLE S LEFT OUTER JOIN DEPARTMENT_TABLE D
ON S.DEPARTMENT_ID = D.DEPARTMENT_ID;
- 오른쪽 외부 조인(RIGHT OUTER JOIN)
- 좌측 테이블에 조인할 컬럼의 값이 없는 경우 사용
- 우측 테이블의 모든 데이터를 포함하는 결과 집합을 생성
- 공통적인 부분 + RIGHT 테이블에 있는 데이터만 SELECT
SELECT *
FROM STUDENT_TABLE S RIGHT OUTER JOIN DEPARTMENT_TABLE D
ON S.DEPARTMENT_ID = D.DEPARTMENT_ID;
- 완전 외부 조인(FULL OUTER JOIN)
- 양쪽 테이블 모두 OUTER JOIN이 필요할 때 사용
- 두 테이블 모든 데이터 SELECT
오라클에서는 OUTER JOIN 연산이 있지만, MYSQL은 없다.
그렇기 때문에, MYSQL에서는 LEFT OUTER JOIN + RIGHT OUTER JOIN을 같이 사용하여 FULL OUTER JOIN을 사용한다.
-- ORACLE
SELECT *
FROM STUDENT_TABLE S FULL OUTER JOIN DEPARTMENT_TABLE D
ON S.DEPARTMENT_ID = D.DEPARTMENT_ID;
-- MYSQL
SELECT *
FROM STUDENT_TABLE S LEFT OUTER JOIN DEPARTMENT_TABLE D
ON S.DEPARTMENT_ID = D.DEPARTMENT_ID
UNION
SELECT *
FROM STUDENT_TABLE S RIGHT OUTER JOIN DEPARTMENT_TABLE D
ON S.DEPARTMENT_ID = D.DEPARTMENT_ID;
4. 조인 사용 시 주의사항
- SQL 문장의 의미를 제대로 파악 필요
- SQL 작성하는 방법에 따라 성능이 크게 좌우된다.
- 어떤 질의를 수행할 것인지를 명확하게 정의한 후, 비효율을 제거하여 최적의 SQL을 작성한다.
- 명확한 조인 조건을 제공
- 조인 조건을 명확하게 제공하지 않을 경우, 의도치 않게 CROSS JOIN(Cartesian Prdouct)이 수행 될 수 있다.
5. 조인 사용 시 고려사항
- 조인할 대상의 집합을 최소화
- 집합을 최소화할 방법이 있으면, 조건을 먼저 적용하여 관계를 맺을 집합을 최소화한 후, 조인을 맺는 것이 효율적이다.
- 효과적인 인덱스 활용
- 인덱스를 활용하면, 조인 연산의 비용을 극적으로 낮출 수 있다.
참고
- https://doooyeon.github.io/2018/11/11/database-join.html
- https://pearlluck.tistory.com/46
반응형