MERGE 与NO

    xiaoxiao2021-11-13  42

    19. /*+ MERGE(TABLE) */     能够对视图的各个查询进行相应的合并.     例如:     SELECT /*+ MERGE(V) */ A.EMP_NO,A.EMP_NAM,B.DPT_NO FROM BSEMPMS A (SELET DPT_NO     ,AVG(SAL) AS AVG_SAL FROM BSEMPMS B GROUP BY DPT_NO) V WHERE A.DPT_NO=V.DPT_NO     AND A.SAL>V.AVG_SAL;   20. /*+NO_MERGE(TABLE)*/     对于有可合并的视图不再合并.     例如:     SELECT /*+NO_MERGE(V) */ A.EMP_NO,A.EMP_NAM,B.DPT_NO FROM BSEMPMS A (SELECT DPT_NO,AVG(SAL) AS AVG_SAL FROM BSEMPMS B GROUP BY DPT_NO) V WHERE A.DPT_NO=V.DPT_NO AND A.SAL>V.AVG_SAL;     21. /*+ORDERED*/    SELECT /*+no_merge(XJ) */               (SELECT DISTINCT T.ZUOY_STAFF FROM VIW_YW_ZYRYJL T WHERE T.DANJ_NO=XJ.DANJ_NO AND T.HANGHAO=XJ.HANGHAO AND T.CAOZJS_ID IN(                SELECT A.JIAOS_ID FROM KH_JC_JSZD A WHERE A.JIAOS_NAME IN('拆零拣货员','整件拣货员'))) ZUOY_STAFF,                XJ.DANJ_NO,                SP.SHANGP_NO,                SUM(XJ.SHIJ_NUM) ZSL,                COUNT(DISTINCT XJ.DANJ_NO||XJ.HANGHAO) TMS,                COUNT(DISTINCT XJ.SHANGP_ID) PGS,                ROUND(SUM(XJ.SHIJ_NUM / SP.BAOZ_NUM),2) JS           FROM  JC_SPZL SP,VIW_CK_KPD_HZ ZY, VIW_YW_XJZL XJ          WHERE ZY.DANJ_NO = XJ.DANJ_NO            AND SP.SHANGP_ID = xj.SHANGP_ID            AND XJ.YEW_TYPE IN ('2', '3')            AND XJ.KUB = 'LHK'            AND XJ.HUOW_ID <> '冲'        --    and  TRUNC(cast(SHENGCHEN_TIME AS DATE)) >= TRUNC(TO_DATE('2016-06-22' ,'yyyy-mm-dd'))         --   AND  TRUNC(cast(SHENGCHEN_TIME AS DATE)) <  TRUNC(TO_DATE('2016-06-22' ,'yyyy-mm-dd') + 1)           AND cast(XJ.SHENGCHEN_TIME AS DATE) >= TRUNC(TO_DATE('2016-06-01' ,'yyyy-mm-dd'))            AND cast(XJ.SHENGCHEN_TIME AS DATE) <  TRUNC(TO_DATE('2016-06-22' ,'yyyy-mm-dd') + 1)            AND XJ.SHIJ_NUM > 0            AND SUBSTR(SP.SHANGP_NO,1,1) <>'P'            AND SUBSTR(SP.SHANGP_NO,1,1)<>'Z'          GROUP BY                   XJ.DANJ_NO,                   XJ.PINGX_NO,                   XJ.HANGHAO,                   SP.SHANGP_NO,                   XJ.LOT qn@RAC> select b.a,v.x from b b,( select a,count(1) x  from a  group by a ) v where b.a=v.a and b.a=1   2  / --优化器选择为NO_MERGE(v),HASH GROUP BY 的视图里操作,谓词推入成功; NO_MERGE 表示视图不合并,不展开 Execution Plan ---------------------------------------------------------- Plan hash value: 1009994850 ----------------------------------------------------------------------------- | Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     | ----------------------------------------------------------------------------- |   0 | SELECT STATEMENT     |        |      4 |    156 |      6   (0)| 00:00:01 | |*  1 |  HASH JOIN         |        |      4 |    156 |      6   (0)| 00:00:01 | |*  2 |   TABLE ACCESS FULL  | B    |      1 |     13 |      3   (0)| 00:00:01 | |   3 |   VIEW             |        |      4 |    104 |      3   (0)| 00:00:01 | |   4 |    HASH GROUP BY     |        |      4 |     52 |      3   (0)| 00:00:01 | |*  5 |     TABLE ACCESS FULL| A    |      4 |     52 |      3   (0)| 00:00:01 | ----------------------------------------------------------------------------- Predicate Information (identified by operation id): ---------------------------------------------------    1 - access("B"."A"="V"."A")    2 - filter("B"."A"=1)    5 - filter("A"=1) Note -----    - dynamic sampling used for this statement (level=2)     --强制为MERGE视图展开,b与v合并在一起。 HASH GROUP BY 在视图外操作,谓词推入成功 qn@RAC> select /*+ MERGE(v) */ b.a,v.x from b b,( select a,count(1) x  from a  group by a ) v where b.a=v.a and b.a=1 Execution Plan ---------------------------------------------------------- Plan hash value: 583771949 ---------------------------------------------------------------------------- | Id  | Operation        | Name | Rows  | Bytes | Cost (%CPU)| Time       | ---------------------------------------------------------------------------- |   0 | SELECT STATEMENT    |       |     4 |   152 |     7  (15)| 00:00:01 | |   1 |  HASH GROUP BY        |       |     4 |   152 |     7  (15)| 00:00:01 | |*  2 |   HASH JOIN        |       |     4 |   152 |     6   (0)| 00:00:01 | |*  3 |    TABLE ACCESS FULL| B    |     1 |    25 |     3   (0)| 00:00:01 | |*  4 |    TABLE ACCESS FULL| A    |     4 |    52 |     3   (0)| 00:00:01 | ---------------------------------------------------------------------------- Predicate Information (identified by operation id): ---------------------------------------------------    2 - access("B"."A"="A")    3 - filter("B"."A"=1)    4 - filter("A"=1) 小结:    MERGE与NO_MERGE并不影响谓词推入    MERGE 是什么与视图合并关联    NO_MERGE 是视图做合并关联 MERGE才是展开视图并做关联 qn@RAC> select  b.a,count(1) from  b b,a a where a.a=b.a and b.a=1 group by b.a   2  / Execution Plan ---------------------------------------------------------- Plan hash value: 759381190 ----------------------------------------------------------------------------- | Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     | ----------------------------------------------------------------------------- |   0 | SELECT STATEMENT     |        |      4 |    104 |      6   (0)| 00:00:01 | |   1 |  SORT GROUP BY NOSORT|        |      4 |    104 |      6   (0)| 00:00:01 | |*  2 |   HASH JOIN         |        |      4 |    104 |      6   (0)| 00:00:01 | |*  3 |    TABLE ACCESS FULL | B    |      1 |     13 |      3   (0)| 00:00:01 | |*  4 |    TABLE ACCESS FULL | A    |      4 |     52 |      3   (0)| 00:00:01 | ----------------------------------------------------------------------------- Predicate Information (identified by operation id): ---------------------------------------------------    2 - access("A"."A"="B"."A")    3 - filter("B"."A"=1)    4 - filter("A"."A"=1) qn@RAC> select /*+ MERGE(v)*/ b.a,v.x from b b,( select a,count(1) x  from a  group by a ) v where b.a=v.a and b.a=1  2   Execution Plan ---------------------------------------------------------- Plan hash value: 583771949 ---------------------------------------------------------------------------- | Id  | Operation        | Name | Rows  | Bytes | Cost (%CPU)| Time       | ---------------------------------------------------------------------------- |   0 | SELECT STATEMENT    |       |     4 |   152 |     7  (15)| 00:00:01 | |   1 |  HASH GROUP BY        |       |     4 |   152 |     7  (15)| 00:00:01 | |*  2 |   HASH JOIN        |       |     4 |   152 |     6   (0)| 00:00:01 | |*  3 |    TABLE ACCESS FULL| B    |     1 |    25 |     3   (0)| 00:00:01 | |*  4 |    TABLE ACCESS FULL| A    |     4 |    52 |     3   (0)| 00:00:01 | ---------------------------------------------------------------------------- Predicate Information (identified by operation id): ---------------------------------------------------    2 - access("B"."A"="A")    3 - filter("B"."A"=1)    4 - filter("A"=1)
    转载请注明原文地址: https://ju.6miu.com/read-678249.html

    最新回复(0)