inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

시니어 백엔드 개발자가 알려주는 데이터베이스 개론 & SQL

쿼리 안의 쿼리 (subquery)

SQL NOT EXISTS사용과 관련하여 질문이 있습니다.

87

언제나처음처럼

작성한 질문수 1

0

안녕하세요. 강의 잘 듣고 있습니다.

강의 16:18 정도에 나오는 2000년대생이 없는 부서의 id와 name을 찾는 것에서 아래와 같이 쿼리를 하셨는데요:

mysql> SELECT D.id, D.name 
    -> FROM department AS D 
    -> WHERE NOT EXISTS (
    -> SELECT * FROM employee E 
    -> WHERE D.id = E.dept_id and E.birth_date >= '2000-01-01');

 

위의 쿼리를 다음과 같이 바꾸니 아무런 결과가 출력되지 않고 Empty set이라고 나옵니다. 혹시 이유를 알 수 있을까요? 두 쿼리에서 다른점은 빨간 글씨로 써놨는데요. subquery에서 department를 다시 D로 한번 불러준 것 외엔 없습니다.

 

mysql> SELECT D.id, D.name 
    -> FROM department AS D 
    -> WHERE NOT EXISTS( 
    -> SELECT *   FROM employee E , department D  
    -> WHERE D.id =E.dept_id AND E.birth_date >= '2000-01-01');

Empty set (0.00 sec)

 

감사합니다.

sql dbms/rdbms

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

언제나처음처럼님, 제시하신 SQL 쿼리에 대해 설명 드리겠습니다.

첫 번째 쿼리에서는 NOT EXISTS 절 내의 서브쿼리에서 employee 테이블과 department 테이블의 조건을 비교하는 방식으로 작성되어 있습니다. 이대로라면 각 부서마다 2000년 이후에 태어난 직원이 존재하지 않는 부서를 반영하는 올바른 결과가 반환됩니다.

하지만 두 번째 쿼리에서는 employee 테이블과 department 테이블이 함께 FROM 절에 명시되어 있습니다. 이렇게 되면 모든 employee-department 조합이 생성되며, Cartesian Product가 발생합니다. 그로 인해 D.id = E.dept_id 조건이 충족되면서 여전히 2000년 이후에 태어난 직원이 존재한다고 해석되기 때문에, 결국 NOT EXISTS 절이 항상 FALSE를 반환하게 됩니다. 그러므로 “Empty set”으로 결과가 나오게 된 것입니다.

서브쿼리 내에서 department 테이블을 중복해서 불러올 필요가 없으며, 첫 번째 쿼리 형태로 유지하는 것이 올바른 결과를 얻는 데 적합합니다.

감사합니다.

간단한 오타 제보입니다.

0

3

0

큰 범위 조회 시 EXPLAIN의 rows 값이 정확하지 않은 이유가 궁금합니다.

0

19

1

실제 FK제약조건을 설정하지 않는이유

0

19

1

Sequence 관련 질문

1

26

2

Image Only Query

1

24

2

Free Edition 실습 영상은 아직 업데이트전인가요?

0

16

1

라이브 운영중인 환경의 테이블에 인덱스 추가시 고려사항

0

29

2

상품 정보 크롤링

0

23

2

강의에 적용한 스크립트를 받아 볼수 있을까요?

0

38

2

실습소실행안되요

0

33

1

수강기간 연장

0

25

1

다양한 관점의 코드 경험을 위해 개선하지 않은 코드

1

47

1

BCNF 질문

0

46

2

연관 엔티티 네이밍 규칙

0

39

1

ORA-01017 오류 때문에 진도가 못나가고있습니다.!

0

35

2

6강 - 해시태그 모델의 샤딩 전략에 대하여, 분산 정도(데이터 편중)와 트랜잭션 성능의 trade off 상황 발생 시에 대한 고민

0

36

2

2022년 2회차 실기 4번

0

24

1

히스토리 관련 질문

0

55

2

SSMS 설치 오류

0

48

1

강의자료 다운 질문..

0

109

1

요청사항이 있습니다!

0

217

1

테이블 조인(join) 강의에서 마지막 join 예제에 대한 질문이 있습니다.

0

440

1

D.leader_id를 E.id로 변경해도 되나요??

0

369

1

강의자료

0

754

1