질문입니다!
안녕하세요~!
혹시 마지막 문제 쿼리에서
WHERE 학번 IN (SELECT 학번 FROM 학생 WHERE 학생.학번 = 성적.학번 AND 학생.학과 IN ('전산', '전기') AND 학생.주소 = '경기');
가 아닌
WHERE EXISTS (SELECT 학번 FROM 학생 WHERE 학생.학번 = 성적.학번 AND 학생.학과 IN ('전산', '전기') AND 학생.주소 = '경기');
게 맞나용..?
답변 2
1
안녕하세요, 해당 챕터의 쿼리는 제가 한번씩 돌려보고 올린거라 틀리지는 않을 겁니다.
혹시 이상하면, 온라인 SQL 사이트에서 한 번 수행해보시는 것을 추천드립니다..!
0
안녕하세요, 인프런 AI 인턴입니다. 배배꼬님.
해당 SQL 쿼리에서는 IN과 EXISTS 두 가지 모두 사용 가능합니다만, 상황에 따라 효율성에 차이가 있을 수 있습니다.
IN절은 비교하는 목록에 특정 값이 포함되어 있는지를 확인합니다. 서브쿼리의 결과로 반환된 값들이 테이블의 열과 비교되게 됩니다.
예를 들어:
WHERE 학번 IN (SELECT 학번 FROM 학생 WHERE 학생.학번 = 성적.학번 AND 학생.학과 IN ('전산', '전기') AND 학생.주소 = '경기');
EXISTS절는 조건이 참인지 여부만을 확인합니다. 서브쿼리가 레코드를 반환하는 경우에만 조건이 참으로 간주됩니다.
예를 들어:
WHERE EXISTS (SELECT 1 FROM 학생 WHERE 학생.학번 = 성적.학번 AND 학생.학과 IN ('전산', '전기') AND 학생.주소 = '경기');
성능 측면에서 EXISTS는 일반적으로 많은 값을 포함한 결과와 비교할 때 IN보다 빠를 수 있습니다. 왜냐하면 EXISTS는 첫 번째로 발견되는 레코드에만 반응하기 때문입니다.
부가적인 설명이나 유사한 사례의 성능 차이를 확인하고 싶다면, 다음 질문을 참고하시기 바랍니다:
- 평소에 궁금했던 SQL 문의드립니다: 이 게시물에서는 다양한 SQL 조건문 사용법과 효과에 대해 설명합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
필기자료 사라졌나요?(실기 일주일만에 안돼서 재도전-_-)
0
51
2
26년 1회 실기 해설 강의
0
68
2
53번 4-1 자료 오류 있는 것 같습니다.
0
73
2
7번문제
0
60
2
C언어 변형문제 9번문제 Pdf 수정요청
0
48
2
메서드 오버드라드
0
51
2
실수
0
46
1
공부 우선순위 우선강의 알려주세요
0
90
1
생성자 호출순서 강의 10번 문제 30분대 질문입니다
0
49
2
25년 2회 기출 5:40 질문입니다.
0
43
2
모의고사1회 3번 파이썬문제
0
75
2
C언어 출제변형 6번 문제
0
50
2
c언어 출제변형 강의 질문
0
32
2
28:40
0
34
2
C : 언어 배열과 문자열 수업자료
0
31
2
파이썬 리스트, 딕셔너리 질문
0
43
2
모의고사 관련 질문 건
1
69
3
자료 내용 오류
0
64
2
정적 변수, 정적 메서드(static) v2
0
51
2
v1.2 와 v0.91 PDF
0
104
1
업캐스팅 (부모형태, 자식생성자)
0
51
2
정보처리산업기사 준비중입니다.
0
74
2
실기 D -6
0
105
2
(기출) 2024년 2회 기출문제 - 이론 포함 22분32초 질문입니다
0
60
3





