inflearn logo
강의

講義

知識共有

実務ですぐに使えるSQLチューニング45選

チューニング例36. サブクエリ文チューニング3. サブクエリをハッシュセミジョインに誘導する

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

47

ssh9414245763

投稿した質問数 6

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 데이터-엔지니어링

回答 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 수행 시 데이터 전송의 부하를 고려해야 합니다.

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

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

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

0

2

1

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

0

11

1

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

0

26

2

상품 정보 크롤링

0

21

2

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

0

35

2

실습소실행안되요

0

30

1

수강기간 연장

0

24

1

BCNF 질문

0

42

2

연관 엔티티 네이밍 규칙

0

36

1

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

0

32

2

히스토리 관련 질문

0

51

2

SSMS 설치 오류

0

46

1

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

1

42

1

최신 하드웨어에서 SQL Express 설치에러 해결법

0

51

1

자료가 남지않은 프로젝트는 어떻게 적어야 할까요?

0

36

2

virtual box 설치 문제

0

56

2

진짜 강의 듣는거 너무 고문

0

103

1

vs code

0

43

2

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

0

32

2

로그인이 안되네요

0

30

1

nosql -> sql 비교

0

32

1

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

0

73

2

안녕하세요 NESTED LOOP 문제에서

0

60

2

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

0

87

2