인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

배배꼬님의 프로필 이미지

작성한 질문수

(2025) 일주일만에 합격하는 정보처리기사 실기

SQL - 2. DML

질문입니다!

해결된 질문

작성

·

60

·

수정됨

0

안녕하세요~!

혹시 마지막 문제 쿼리에서

WHERE 학번 IN (SELECT 학번 FROM 학생 WHERE 학생.학번 = 성적.학번 AND 학생.학과 IN ('전산', '전기') AND 학생.주소 = '경기');

가 아닌

WHERE EXISTS (SELECT 학번 FROM 학생 WHERE 학생.학번 = 성적.학번 AND 학생.학과 IN ('전산', '전기') AND 학생.주소 = '경기');

게 맞나용..?

답변 2

1

주말코딩님의 프로필 이미지
주말코딩
지식공유자

안녕하세요, 해당 챕터의 쿼리는 제가 한번씩 돌려보고 올린거라 틀리지는 않을 겁니다.

 

혹시 이상하면, 온라인 SQL 사이트에서 한 번 수행해보시는 것을 추천드립니다..!

배배꼬님의 프로필 이미지
배배꼬
질문자

아아 상관, 비상관에 따른 차이 이해했습니다!

감사합니다~!

0

인프런 AI 인턴님의 프로필 이미지

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

해당 SQL 쿼리에서는 INEXISTS 두 가지 모두 사용 가능합니다만, 상황에 따라 효율성에 차이가 있을 수 있습니다.

  1. IN은 비교하는 목록에 특정 값이 포함되어 있는지를 확인합니다. 서브쿼리의 결과로 반환된 값들이 테이블의 열과 비교되게 됩니다.

예를 들어:

   WHERE 학번 IN (SELECT 학번 FROM 학생 WHERE 학생.학번 = 성적.학번 AND 학생.학과 IN ('전산', '전기') AND 학생.주소 = '경기');
  1. EXISTS는 조건이 참인지 여부만을 확인합니다. 서브쿼리가 레코드를 반환하는 경우에만 조건이 참으로 간주됩니다.

예를 들어:

   WHERE EXISTS (SELECT 1 FROM 학생 WHERE 학생.학번 = 성적.학번 AND 학생.학과 IN ('전산', '전기') AND 학생.주소 = '경기');

성능 측면에서 EXISTS는 일반적으로 많은 값을 포함한 결과와 비교할 때 IN보다 빠를 수 있습니다. 왜냐하면 EXISTS는 첫 번째로 발견되는 레코드에만 반응하기 때문입니다.

부가적인 설명이나 유사한 사례의 성능 차이를 확인하고 싶다면, 다음 질문을 참고하시기 바랍니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.