트러블슈팅 오라클 퍼포먼스 2판 (2017년)
쿼리 변환 - 조인 FACTORIZATION 0 0 44,762

by 구루비스터디 쿼리변환 조인FACTORIZATION FACTORIZE_JOIN [2023.09.08]


쿼리 변환 - 조인 FACTORIZATION



SQL> SELECT /*+ FACTORIZE_JOIN(@"SET$1") */ *
  2  FROM t1, t2
  3  WHERE t1.id = t2.id AND t2.id < 10
  4  UNION ALL
  5  SELECT *
  6  FROM t1, t2
  7  WHERE t1.id = t2.id AND t2.id > 990;
SQL> SELECT * FROM table(dbms_xplan.display_cursor(format=>'basic'));

PLAN_TABLE_OUTPUT
--------------------------------------------------------------------------------------------------

EXPLAINED SQL STATEMENT:
------------------------
SELECT /*+ FACTORIZE_JOIN(@"SET$1") */ * FROM t1, t2 WHERE t1.id =
t2.id AND t2.id < 10 UNION ALL SELECT * FROM t1, t2 WHERE t1.id = t2.id
AND t2.id > 990

Plan hash value: 1282049862

---------------------------------------------------
| Id  | Operation            | Name               |
---------------------------------------------------
|   0 | SELECT STATEMENT     |                    |
|   1 |  HASH JOIN           |                    |
|   2 |   VIEW               | VW_JF_SET$3DF3FC68 |
|   3 |    UNION-ALL         |                    |
|   4 |     TABLE ACCESS FULL| T2                 |
|   5 |     TABLE ACCESS FULL| T2                 |
|   6 |   TABLE ACCESS FULL  | T1                 |
---------------------------------------------------

SQL> SELECT /*+ NO_FACTORIZE_JOIN(@"SET$1") */ *
  2  FROM t1, t2
  3  WHERE t1.id = t2.id AND t2.id < 10
  4  UNION ALL
  5  SELECT *
  6  FROM t1, t2
  7  WHERE t1.id = t2.id AND t2.id > 990;
SQL> SELECT * FROM table(dbms_xplan.display_cursor(format=>'basic'));

PLAN_TABLE_OUTPUT
--------------------------------------------------------------------------------------------------

EXPLAINED SQL STATEMENT:
------------------------
SELECT /*+ NO_FACTORIZE_JOIN(@"SET$1") */ * FROM t1, t2 WHERE t1.id =
t2.id AND t2.id < 10 UNION ALL SELECT * FROM t1, t2 WHERE t1.id = t2.id
AND t2.id > 990

Plan hash value: 4147288133

------------------------------------
| Id  | Operation           | Name |
------------------------------------
|   0 | SELECT STATEMENT    |      |
|   1 |  UNION-ALL          |      |
|   2 |   HASH JOIN         |      |
|   3 |    TABLE ACCESS FULL| T1   |
|   4 |    TABLE ACCESS FULL| T2   |
|   5 |   HASH JOIN         |      |
|   6 |    TABLE ACCESS FULL| T1   |
|   7 |    TABLE ACCESS FULL| T2   |
------------------------------------


"데이터베이스 스터디모임" 에서 2017년에 "전문가를 위한 트러블슈팅 오라클 퍼포먼스(Second Edition) " 도서를 스터디하면서 정리한 내용 입니다.

- 강좌 URL : http://www.gurubee.net/lecture/4367

- 구루비 강좌는 개인의 학습용으로만 사용 할 수 있으며, 다른 웹 페이지에 게재할 경우에는 출처를 꼭 밝혀 주시면 고맙겠습니다.~^^

- 구루비 강좌는 서비스 제공을 위한 목적이나, 학원 홍보, 수익을 얻기 위한 용도로 사용 할 수 없습니다.

댓글등록
SQL문을 포맷에 맞게(깔끔하게) 등록하려면 code() 버튼을 클릭하여 작성 하시면 됩니다.
로그인 사용자만 댓글을 작성 할 수 있습니다. 로그인, 회원가입