- [MySQL] 45. 서브 쿼리 (2)2024년 06월 13일
- Song hyun
- 작성자
- 2024.06.13.:51
728x90반응형[MySQL] 45. 서브 쿼리 (2)
1. 서브 쿼리
2. 서브 쿼리의 형태
3. 서브 쿼리를 사용하는 이유?
4. 서브 쿼리의 종류
5. 코드 예제: 중첩 서브 쿼리를 사용해 조회해보자.
6. 코드 예제: 인라인 뷰를 사용해 조회해보자.
1. 서브 쿼리
(1) 서브 쿼리(Subquery): 서브 쿼리는 SQL 문장 내에서 다른 SQL 쿼리를 내포하는 구문이다.
(2) 서브 쿼리의 개념: 서브 쿼리는 보통 소괄호() 안에 작성되며, 메인쿼리/외부 쿼리(main query/outer query)라고 하는 더 큰 SQL 쿼리의 일부로 존재한다. 서브 쿼리는 메인 쿼리에 의해 반환된 데이터를 기반으로 추가적인 조건을 적용하거나, 메인 쿼리의 조건을 정의하는 데 사용한다.
2. 서브 쿼리의 형태
select * from reservation where name in( select name from customer where address ='서울' );
3. 서브 쿼리를 사용하는 이유?
(1) 복잡성 감소: 복잡한 쿼리를 더 작고 관리하기 쉬운 부분으로 나누어 처리할 수 있다.
(2) 재사용성: 같은 서브쿼리를 여러 쿼리에서 재사용할 수 있어, 코드의 중복을 줄이고 윶 보수를 용이하게 한다.
(3) 명확성: 데이터의 특정 부분에 대해 명확한 조건을 설정할 수 있고, 읽기 쉽고 이해하기 쉬운 쿼리를 작성할 수 있다.
4. 서브 쿼리의 종류
서브 쿼리는 위치에 따라 크게 세 가지 종류로 나뉜다.
(1) 중첩 서브 쿼리(Nested Subquery): WHERE 절에 사용하는 서브 쿼리
(2) 인라인 뷰(Inline view): FROM 절에 사용하는 서브 쿼리
(3) 스칼라 서브 쿼리(Scalar Subquery): SELECT 절에 사용하는 서브 쿼리
5. 코드 예제: 중첩 서브 쿼리를 사용해 조회해보자.
*문제: 서브 쿼리를 활용해, 현재 매니저로 재직 중인 사원들의 명단을 출력해보자.
-employees(사원 명단), dept_manager(매니저 명단) 사용
(1) 현재 재직 중인 매니저를 dept_manager 테이블에서 조회하는 쿼리를 작성한다.
(2) employee 테이블 내에서 emp_no(사원번호)가 (1) 과 동일한 사원을 출력하는 쿼리를 작성한다.
(3) where 조건문에 (1)을 서브쿼리로 삽입한다.
(4) 여러 매니저들을 출력해야 하기 때문에, =이 아닌 in을 사용한다.
6. 코드 예제: 인라인 뷰를 사용해 조회해보자.
*문제: 현재 다니고 있는 매니저들의 평균 연봉 구하기. (인라인 뷰 사용하기)
-Salaries(연봉) 테이블 사용
(1) 전체 직원들의 평균 연봉(avg(salary))을 구하는 쿼리를 만든다.
(2) 사원번호를 group by로 묶는 쿼리문을 작성한 뒤,
(3) 해당 쿼리문의 from 절에 (1)을 삽입한다.
(4) 사원번호가 10001인 사원만을 출력해야 하므로 where emp_no='10001'을 작성한다.
그러면 아래와 같이 성공적으로 출력된 것을 확인할 수 있다.
*코드의 진행 순서
(1) from - from 내부의 인라인 뷰를 읽어들임
(2) where 절을 통해 조건 탐색
(3) select로 쿼리 출력
인라인 뷰와 중첩 서브 쿼리를 동시에 쓸 수도 있다.
-- 인라인 뷰, 중첩 서브쿼리를 동시에 사용 select emp_no, 평균연봉 from (select emp_no, avg(salary) as 평균연봉 from salaries as s group by emp_no) as avg_salary where emp_no in (select emp_no from dept_manager where to_date='9999-01-01');
경우에 따라, 중첩 서브 쿼리는 일반 쿼리보다 쿼리 코스트가 더 많이 들기도 한다.
위의 코드는 JOIN을 사용해 우측 하단처럼 코드를 작성할 수도 있으며,
이 경우에는 JOIN을 사용하는 것이 더욱 효율적인 선택이다.
-- 위와 같은 결과 집합을 INNER JOIN을 활용해 만들어 보자. select dm.emp_no, avg(salary) from dept_manager as dm join salaries as s on dm.emp_no=s.emp_no where dm.to_date='9999-01-01' group by s.emp_no;
* 전체 코드
-- FROM 절에 사용하는 인라인 뷰 -- 현재 다니고 있는 매니저들의 평균 연봉 구하기. select*from dept_manager where to_date='9999-01-01'; select*from salaries where emp_no=10001; -- 전체 직원의 평균 연봉 = avg(emp_no 그룹 by 처리) select emp_no, avg(salary) as 평균연봉 from salaries as s group by emp_no; -- 인라인 뷰, 중첩 서브쿼리를 동시에 사용 select emp_no, 평균연봉 from (select emp_no, avg(salary) as 평균연봉 from salaries as s group by emp_no) as avg_salary where emp_no in (select emp_no from dept_manager where to_date='9999-01-01'); -- 위와 같은 결과 집합을 INNER JOIN을 활용해 만들어 보자. select dm.emp_no, avg(salary) from dept_manager as dm join salaries as s on dm.emp_no=s.emp_no where dm.to_date='9999-01-01' group by s.emp_no;
728x90반응형'MySQL > 응용 및 DB 접근' 카테고리의 다른 글
[MySQL] 47. 정규화(2) -제 1 정규화(1NF) (0) 2024.06.13 [MySQL] 46. 서브 쿼리(3) (0) 2024.06.13 [MySQL] 44. 연습문제 풀이 (0) 2024.06.13 [MySQL] 43. 연습 문제: 서브 쿼리 및 기본 개념 다지기 (0) 2024.06.12 [MySQL] 42. 서브 쿼리 (0) 2024.06.12 다음글이전글이전 글이 없습니다.댓글