11. 집합 연산을 조인으로 변환
2011.06.08 04:16
-Intersect 나 Minus 같은 집합 연산을 조인 형태로 변환하는 것을 말함
_________________________________________________________________________________________________________________
TEST
-deptno=10에 속한 사원들의 job,mgr을 제외시키고 나머지 job,mgr 집합만을 찾는 쿼리
SQL> set autotrace traceonly exp; Execution Plan ----------------------------------------------------------------- Predicate Information (identified by operation id): 5 - filter("DEPTNO"=10) |
*각각 sort unique 연산을 수행한 후에 Minus연산을 수행
-_convert_set_to_join 파라미터를 true로 설정
SQL> alter session set "_convert_set_to_join" = true; 세션이 변경되었습니다. SQL> select job, mgr from emp Execution Plan ----------------------------------------------------------------- Predicate Information (identified by operation id): 2 - access(SYS_OP_MAP_NONNULL("JOB")=SYS_OP_MAP_NONNULL("JOB") AND |
*해시 anti 조인을 수행하고 나서 중복 값을 제거하기 위한 hash unique 연산을 수행
-다음과 같은 쿼리 변환이 일어남
SQL> select distinct job, mgr from emp e Execution Plan ----------------------------------------------------------------- Predicate Information (identified by operation id): 2 - access(SYS_OP_MAP_NONNULL("JOB")=SYS_OP_MAP_NONNULL("E"."JOB") |
*sys_op_map_nonnull
null 값끼리 비교(null=null)하면 false이지만 가끔 true가 되도록 처리해야 하는 경우가 있고 그럴 때 위 함수를 사용
위에서는 job과 mgr이 null 허용 컬럼이기 때문에 위와 같은 처리가 일어난다
댓글 0
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
55 | 4장._쿼리_변환 | 휘휘 | 2011.09.07 | 2394 |
54 | 진행기록 | 운영자 | 2011.08.23 | 2383 |
53 | 2. 병렬 Order By와 Group By | 휘휘 | 2011.06.30 | 10127 |
52 | 3. 병렬 조인 | 오예스 | 2011.06.29 | 4969 |
51 | 4. PQ_DISTRIBUTE 힌트 | 휘휘 | 2011.06.27 | 15620 |
50 | 5. 병렬 처리에 관한 기타 상식 [1] | balto | 2011.06.26 | 28162 |
49 | 1. 테이블 파티셔닝 | 오라클잭 | 2011.06.21 | 28274 |
48 | 2. 파티션 Pruning | 휘휘 | 2011.06.19 | 11868 |
47 | 7. Sort Area 크기 조정 | 오예스 | 2011.06.16 | 5987 |
46 | 5. 인덱스를 이용한 소트 연산 대체 | AskZZang | 2011.06.16 | 4955 |
45 | 4. 소트가 발생하지 않도록 SQL 작성 | AskZZang | 2011.06.16 | 3109 |
44 | 3. 데이터 모델 측면에서의 검토 | AskZZang | 2011.06.16 | 2724 |
43 | 5장. 소트 튜닝 | balto | 2011.06.16 | 4283 |
42 | 6. Sort Area를 적게 사용하도록 SQL 작성 | 오예스 | 2011.06.14 | 4209 |
41 | 1. 소트 수행 원리 | balto | 2011.06.12 | 8025 |
40 | 2. 소트를 발생시키는 오퍼레이션 | balto | 2011.06.12 | 4847 |
» | 11. 집합 연산을 조인으로 변환 | 오라클잭 | 2011.06.08 | 4956 |
38 | 10. 실체화 뷰 쿼리로 재작성 | 오라클잭 | 2011.06.08 | 9953 |
37 | 12. 기타 쿼리 변환 | 휘휘 | 2011.06.06 | 3122 |
36 | 7. OR-Expansion | AskZZang | 2011.06.01 | 8334 |