inflearn logo
강의

Course

Instructor

45 SQL Tuning Techniques You Can Use Right Away in Practice

Tuning Example 36. Subquery Tuning 3. Inducing Subqueries to Hash Semi Join

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

50

ssh9414245763

6 asked

0

SELECT COUNT(*)

FROM ORDERS

WHERE MEMBER_ID IN (

SELECT /*+ UNNEST HASH_SJ */ MEMBER_ID

FROM MEMBERS

WHERE CITY = 'Busan'

);

이렇게 진행을 하더라도 옵티마이저가 멋대로 HASH JOIN RIGHT SEMI로 MEMBERS를 선행해버리네요

image.png

sql oracle 데이터-엔지니어링

Answer 1

0

communityai8509

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

질문하신 사항은 SQL 옵티마이저와 쿼리 힌트 사용에 관한 내용인 것 같습니다. 쿼리 실행 계획에서 옵티마이저가 예상과 다른 방향으로 작동할 때는 몇 가지 고려해야 할 사항이 있습니다.

  1. 옵티마이저의 역할: SQL 옵티마이저는 쿼리 실행 시 최적의 성능을 내기 위해 관계형 DBMS에서 사용 가능한 다양한 실행 계획 중 하나를 선택합니다. 이 과정에서 사용 가능한 통계 정보를 바탕으로 효율적인 쿼리 경로를 설정하며, 가끔 미리 정의된 힌트가 무시될 수도 있습니다.

  2. HASH JOIN RIGHT SEMI: 옵티마이저가 HASH JOIN RIGHT SEMI 전략을 사용한 것은 아마도 이 방법이 현재 통계 하에서 가장 효율적이라고 판단했기 때문입니다. RIGHT SEMI JOIN은 대개 조인의 한 쪽(이 경우, MEMBERS)에 특정 조건이 걸려 있어 그 조건이 만족되는 경우에만 결합하는 데 사용됩니다.

  3. 통계 정보 갱신: 옵티마이저의 판단이 예상과 다르다면, 통계 정보가 최신 상태가 아닌 경우가 있을 수 있습니다. 새로운 데이터 입력이나 데이터 분포의 변화가 있었을 경우 통계 정보를 갱신해주세요.

  4. 힌트의 효용성: /*+ UNNEST HASH_SJ */ 힌트는 성능 개선을 위한 의도를 전달하지만, 모든 경우에 유효하지 않을 수 있습니다. 힌트는 옵티마이저의 결정에 강제성을 부여하지 않으며, 여러 실행 경로 중 최상이라고 생각되는 경우에 제한적으로 적용됩니다.

  5. 인덱스 및 하드웨어 고려: 적절한 인덱스가 설정되어 있는지, 그리고 하드웨어 성능에 따른 영향을 검토하는 것도 중요합니다. ORDER 멤버 테이블의 크기와 JOIN 수행 시 데이터 전송의 부하를 고려해야 합니다.

관련된 문제를 해결하는 데 도움이 될 수 있는 추가 정보를 얻기 위해 게시판의 유사한 토론을 참고하실 수 있습니다:

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

강사님 안녕하세요 ㅎdatabricks환경에 대한 설

0

1

1

노션 링크도 안 열리고, 알려준 vercel도 실행이 안됩니다.

0

12

1

astro dev start - python 라이브러리 설치 fail

0

23

1

코드를 첨부해야하는 이유가 있나요?

0

21

2

맥북 환경구성 에러

0

19

2

간단한 오타 제보입니다.

0

19

1

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

0

35

2

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

0

37

2

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

0

22

1

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

0

36

2

상품 정보 크롤링

0

29

2

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

0

40

2

실습소실행안되요

0

39

1

수강기간 연장

0

27

1

BCNF 질문

0

49

2

연관 엔티티 네이밍 규칙

0

40

1

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

0

38

2

히스토리 관련 질문

0

58

2

SSMS 설치 오류

0

50

1

제공된 홈페이지 로그인 ,출력값, 건의사항 오류

1

49

1

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

0

38

2

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

0

76

2

안녕하세요 NESTED LOOP 문제에서

0

62

2

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

0

92

2