일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Eda
- 프로그래머스
- ggplot2
- 지도학습
- python
- 한국전자통신연구원
- 하둡
- KT AIVLE
- dx
- Ai
- SQLD
- ETRI
- 웹크롤링
- httr
- 에이블러
- 하계인턴
- 다변량분석
- kaggle
- 가나다영
- 머신러닝
- matplot
- arima
- kt aivle school
- KT 에이블스쿨
- 빅분기
- 시각화
- 기계학습
- 딥러닝
- hadoop
- r
- 시계열
- 에이블스쿨
- ML
- 소셜네트워크분석
- SQL
- 빅데이터분석기사
- cnn
- 한국전자통신연구원 인턴
- 서평
- 에트리 인턴
Archives
- Today
- Total
소품집
[SQL] 옵티마이저 조인 (Optimizer join) 본문
728x90
Nested Loop 조인
- Nested Loop 조인은 하나의 테이블에서 데이터를 먼저 찾고 그 다음 테이블은 조인하는 방식으로 실행된다.
- Nested Loop 조인에서 먼저 조회되는 테이블을 외부 테이블(Outer Table)이라고 하고 그 다음 조회되는 테이블을 내부 테이블(Inner Table)이라고 한다.
- Nested Loop 조인에서는 외부 테이블(선행 테이블)의 크기가 작은 것을 먼저 찾는 것이 중요하다. 그래야 데이터가 스캔되는 범위를 줄일 수 있기 때문!
- Nested Loop 조인은 RANDOM ACCESS가 발생하는데 RANDOM ACCESS가 많이 발생하면 성능 지연이 발생된다. 그러므로 Nested Loop 조인은 RANDOM ACCESS의 양을 줄여야 성능이 향상된다.
- 위의 예는 Nested Loop 조인 방식을 도식화한 것이다. 즉, T_CUST_SALE의 인덱스를 먼저 검색하고 T_CUST_SALE 인덱스에 있는 ROWID를 사용해서 T_CUST_SALE 테이블을 읽는다.
- 그 다음은 T_CUST_SALE에서 T_CUST_MAST 테이블의 인덱스를 찾는다. 이 부분을 RANDOM ACCESS라고 한다.
- T_CUST_MAST 인덱스를 사용해서 다시 T_CUST_MAST 테이블에서 데이터를 찾는다. 여기까지 실행되면 모든 데이터를 찾은 것이고, 그 다음은 인출(Fetch)을 실행해서 전송한다.
selct /* ordered use_nl(b) * / *
from EMP a, DEPT b
where a.DEPTNO = b.DEPTNO
and a.DEPTNO = 10;
- 위의 예는
- 실행 계획을 보면 EMP 테이블을 먼저 FULL SACN 하고 그다음 DEPT 테이블을 FHULL SCAN 하여 Nested loop 조인을 하는 것
- ordered 힌트는 from 절에 나오는 테이블을 순서대로 조인을 하게 하는 것이다.
SORT Merge 조인
- Sort Merge 조인은 두 개의 테이블을 SORT_AREA라는 메모리 공간에 모두 로딩(loading)하고 SORT를 수행한다.
- 두 개의 테이블에서 SORT가 완료되면 두 개의 테이블을 병합(Merge)한다.
- Sort Merge 조인은 정렬(SORT)가 발생하기 때문에 데이터 양이 많아지면 성능이 떨어지게 됨
- 정렬 데이터 양이 너무 많으면 정렬은 임시영역에서 수행된다. 임시 영역은 디스크에 있기 때문에 성능이 급격히 떨어짐
select /* ordered use_merge(b) */ *
from emp a, dept b
where a.DEPTNO = b.DEPTNO
and a.DEPTNO = 10
- 위의 예는 Oracle 데이터베이스 힌트를 사용해서 의도적으로 SORT MERGE 조인을 한 것
- use_merge 힌트를 사용해서 sort merge 조인을 할 수 있음
- 단, use_merge 힌트는 ordered와 함께 사용해야 함!
Hash Join
- Hash join은 두 개의 테이블 중에서 작은 테이블을 Hash 메모리에 로딩하고 두 개의 테이블의 조인키를 사용해서 해시 테이블을 생성함
- Hash 조인은 해시 함수를 사용해서 주소를 계산하고 해당 주소를 사용해서 테이블을 조인하기 때문에 CPU 연산을 많이 함
- 특히 Hash 조인 시에는 선행 테이블이 충분히 메모리에 로딩되는 크기여야 함
select /* + ordered use_hash(b) */ *
from emp a, dept b
where a.DEPTNO = b.DEPTNO
and a.DEPTNO = 10 ;
! orderd 힌트는 혼자 사용되지 않고 use_nl, use_merge, use_hash 힌트와 함께 사용됨
728x90
'자격증 > SQL' 카테고리의 다른 글
[SQL] JOIN(조인) (0) | 2021.03.09 |
---|---|
[SQL] 연산자 쓰임 및 우선순위 (0) | 2021.03.09 |
[SQL] 문자유형 비교 방법 (0) | 2021.03.09 |
[SQL] 반정규화의 필요성 (0) | 2021.03.09 |
2월달 목표! (0) | 2021.02.15 |
Comments