[sql] RIGHT JOIN을 활용한 데이터 필터링
RIGHT JOIN은 데이터베이스에서 사용되는 JOIN 연산 중 하나로, 오른쪽 테이블의 모든 행과 해당하는 왼쪽 테이블의 행을 포함하여 결과를 반환합니다. 이를 통해 일치하는 행이 없더라도 오른쪽 테이블의 모든 데이터를 포함하는 쿼리를 작성할 수 있습니다.
예를 들어, employees와 departments 테이블이 있다고 가정해보겠습니다. 직원 테이블에는 각 직원의 이름, 직책 및 소속된 부서의 정보가, 부서 테이블에는 부서의 ID, 이름 및 위치 정보가 포함되어 있다고 가정해 봅시다.
우리는 모든 직원의 정보와 그들이 속한 부서의 이름을 함께 조회하고 싶을 수 있습니다. 이때 RIGHT JOIN을 사용하여 부서 테이블의 정보를 모두 포함하면서 직원 정보가 있는 경우 해당 정보를 함께 가져올 수 있습니다.
다음은 이를 SQL로 작성한 예시입니다.
SELECT e.*, d.name as department_name
FROM employees e
RIGHT JOIN departments d
ON e.department_id = d.id;
위의 쿼리는 employees 테이블과 departments 테이블을 department_id 열을 기준으로 RIGHT JOIN하여 모든 부서 정보를 포함하면서 그와 연관된 직원 정보를 함께 조회합니다.
이를 통해, RIGHT JOIN을 활용하여 데이터 필터링 및 결합을 효과적으로 수행할 수 있습니다.
참고 자료:
- MySQL Documentation. (https://dev.mysql.com/doc/refman/8.0/en/join.html)