前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【DB笔试面试619】在Oracle中,举例说明“连接因式分解(Join factorization,JF)”查询转换。

【DB笔试面试619】在Oracle中,举例说明“连接因式分解(Join factorization,JF)”查询转换。

作者头像
AiDBA宝典
发布2019-09-29 16:09:58
3590
发布2019-09-29 16:09:58
举报
文章被收录于专栏:小麦苗的DB宝专栏

题目部分

在Oracle中,举例说明“连接因式分解(Join factorization,JF)”查询转换。

答案部分

代码语言:javascript
复制
LHR@orclasm > SELECT  /*+FULL(A) FULL(B)*/  A.*,B.DNAME FROM SCOTT.EMP A,SCOTT.DEPT B WHERE A.DEPTNO=B.DEPTNO AND A.EMPNO=6
  2  UNION ALL
  3  SELECT  /*+FULL(A) FULL(B)*/  A.*,B.DNAME FROM SCOTT.EMP A,SCOTT.DEPT B WHERE A.DEPTNO=B.DEPTNO AND A.EMPNO=7;

no rows selected


Execution Plan
----------------------------------------------------------
Plan hash value: 1245103347

-------------------------------------------------------------------------------------------
| Id  | Operation            | Name               | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT     |                    |     2 |   244 |     8  (13)| 00:00:01 |
|*  1 |  HASH JOIN           |                    |     2 |   244 |     8  (13)| 00:00:01 |
|   2 |   VIEW               | VW_JF_SET$623BBB07 |     2 |   200 |     4   (0)| 00:00:01 |
|   3 |    UNION-ALL         |                    |       |       |            |          |
|*  4 |     TABLE ACCESS FULL| EMP                |     1 |    87 |     2   (0)| 00:00:01 |
|*  5 |     TABLE ACCESS FULL| EMP                |     1 |    87 |     2   (0)| 00:00:01 |
|   6 |   TABLE ACCESS FULL  | DEPT               |     4 |    88 |     3   (0)| 00:00:01 |
-------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   1 - access("ITEM_1"="B"."DEPTNO")
   4 - filter("A"."EMPNO"=6)
   5 - filter("A"."EMPNO"=7)

Note
-----
   - dynamic sampling used for this statement (level=2)


Statistics
----------------------------------------------------------
         99  recursive calls
          7  db block gets
         32  consistent gets
          0  physical reads
       4536  redo size
        866  bytes sent via SQL*Net to client
        509  bytes received via SQL*Net from client
          1  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          0  rows processed

LHR@orclasm > ALTER SESSION SET "_OPTIMIZER_JOIN_FACTORIZATION"=FALSE; 

Session altered.

LHR@orclasm > SELECT  /*+FULL(A) FULL(B)*/  A.*,B.DNAME FROM SCOTT.EMP A,SCOTT.DEPT B WHERE A.DEPTNO=B.DEPTNO AND A.EMPNO=6
  2  UNION ALL
  3  SELECT  /*+FULL(A) FULL(B)*/  A.*,B.DNAME FROM SCOTT.EMP A,SCOTT.DEPT B WHERE A.DEPTNO=B.DEPTNO AND A.EMPNO=7;

no rows selected


Execution Plan
----------------------------------------------------------
Plan hash value: 2703228680

----------------------------------------------------------------------------
| Id  | Operation           | Name | Rows  | Bytes | Cost (%CPU)| Time     |
----------------------------------------------------------------------------
|   0 | SELECT STATEMENT    |      |     2 |   218 |     8  (50)| 00:00:01 |
|   1 |  UNION-ALL          |      |       |       |            |          |
|   2 |   NESTED LOOPS      |      |     1 |   109 |     4   (0)| 00:00:01 |
|*  3 |    TABLE ACCESS FULL| EMP  |     1 |    87 |     2   (0)| 00:00:01 |
|*  4 |    TABLE ACCESS FULL| DEPT |    82 |  1804 |     2   (0)| 00:00:01 |
|   5 |   NESTED LOOPS      |      |     1 |   109 |     4   (0)| 00:00:01 |
|*  6 |    TABLE ACCESS FULL| EMP  |     1 |    87 |     2   (0)| 00:00:01 |
|*  7 |    TABLE ACCESS FULL| DEPT |    82 |  1804 |     2   (0)| 00:00:01 |
----------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   3 - filter("A"."EMPNO"=6)
   4 - filter("A"."DEPTNO"="B"."DEPTNO")
   6 - filter("A"."EMPNO"=7)
   7 - filter("A"."DEPTNO"="B"."DEPTNO")


Statistics
----------------------------------------------------------
         93  recursive calls
          7  db block gets
         14  consistent gets
          0  physical reads
       4536  redo size
        866  bytes sent via SQL*Net to client
        509  bytes received via SQL*Net from client
          1  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          0  rows processed

本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-08-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 DB宝 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档