inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Tối ưu hóa SQL áp dụng ngay trong thực tế - 45 kỹ thuật

Ví dụ tuning 38. Tuning câu lệnh subquery 5. Tối ưu hóa hiệu suất bằng cách thay đổi toán tử IN thành EXISTS

그 EXISTS의 힌트절에 NESTED LOOP를 쓰는이유 질문

82

ssh9414245763

6 câu hỏi đã được viết

0

EXISTS 힌트절에 NL_SJ을 써야한다고 말씀하셨는데 이게 EXISTS 자체가 하나씩 상관 서브 쿼리에 사용이 되기 때문에 NL_SJ를 써야한다는 거죠?

 

IN 같은 경우는 독립적으로 실행이 가능하기 떄문에 HASH_SJ가 유리한거구요?

sql oracle 데이터-엔지니어링

Câu trả lời 2

0

codingkorea

네, 맞습니다. 질문하신 논리적인 접근이 정확합니다.

기본적으로 EXISTS는 메인 쿼리의 건별로 값을 확인하는 상호연관(Correlated) 특성이 있어 NL 조인의 매커니즘과 유사하고, IN은 독립적인 집합을 먼저 구성하는 성격이라 HASH 조인과 잘 어울리는 것이 사실입니다.

다만 실무 튜닝 관점에서 조금 더 덧붙이자면, 옵티마이저가 서브쿼리를 일반 조인으로 변환(Unnesting)하고 나면 문법보다는 '데이터의 양'과 '인덱스 유무'가 더 중요해집니다. 따라서 EXISTS라도 대용량 처리가 필요하면 HASH_SJ가 유리할 수 있으며, 제가 NL_SJ를 쓴 이유는 문법 때문이라기보다 인덱스를 타고 빠르게 응답을 줘야 하는 상황을 가정했기 때문입니다.

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. c신승호님.

EXISTS 절과 관련된 힌트 사용에 대해 질문 주셨네요. EXISTS 절에서 NL_SJ(Nested Loop Semi-Join) 힌트를 사용하는 이유는 정확히 말씀하신 대로입니다. 하나씩 상관 서브 쿼리에 활용되기 때문에, NESTED LOOP 방식이 적합합니다.

  1. EXISTS와 NL_SJ:

    • EXISTS는 상관 서브쿼리로, 외부 쿼리의 각 행에 대해 내부 쿼리가 반복적으로 실행됩니다. 이런 연산은 일반적으로 NESTED LOOP와 결합이 잘 되며, NL_SJ 힌트를 사용하면 NESTED LOOP 기반으로 처리할 수 있습니다.
  2. IN과 HASH_SJ:

    • 반면, IN절은 독립적으로 실행 가능하여, HASH JOIN이나 블록 기반의 접근 방식이 더 효과적일 수 있습니다. 이 경우 HASH_SJ 힌트를 주면 효율성을 높일 수 있습니다. HASH JOIN은 큰 데이터 그룹에 대해 비교적 빠른 성능을 제공할 수 있습니다.

관련된 내용을 더 깊이 이해하시려면, 다음 게시물을 참고하면 도움이 될 것입니다:
- “SQL 튜닝에서 Nested Loop와 Hash Join의 차이점 이해하기”

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

실습용 테이블, 데이터 생성 파일 있을까요?

1

12

2

extract 함수 관련 질문

1

12

2

강사님.. 하단 URL에 있었던 코드들 다운 받거나 공유 부탁 드립니다..

0

15

2

백업파일이 안보입니다.

0

18

1

강의 연장 요청

0

21

2

최신버젼 다운로드

0

26

2

IN 사용방법 문의

0

17

1

다음 강의는 언제 올려주시는지요?

0

37

2

하단 파일이 열리지 않습니다

0

35

1

ssh-keygen -t rsa -P "" 등 ssh 암호화? 는 하둡에서 필수인가요?

0

28

2

리뷰를 가장 많이 작성한 회원들 조회

0

29

2

회사 내 AI 툴 사용에 대한 질문

0

29

1

일대일 fk 위치

0

30

1

GROUP BY, HAVING 실습 1번문제

1

31

2

수업에서 사용하는 툴 질문드려요

0

40

2

2강에 파일 어디있을까여,,

0

25

2

다음 강의는 언제쯤 나올까요?

0

50

2

땃지님 실습소 DB서버 확인 부탁드립니다

0

30

2

강의자료 문의

0

21

1

GROUP BY 시 인덱스를 타지 않는 이유가 궁금합니다

0

23

1

맥북용 자료 부탁드립니다.

0

42

2

어우 옵티마이저가 뛰어난건지..

0

53

1

안녕하세요 NESTED LOOP 문제에서

0

67

2

Buffers와 TotalCost / cpu_cost / io_cost 의 차이점?

0

96

2