成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle中connect by語句的優化

數據庫 Oracle
很多應用中都會有類似組織機構的表,組織機構的表又通常是典型的層次結構(沒有循環節點)。于是通過組織控制數據權限的時候,許多人都喜歡通過connect by獲得組織信息,然后再過濾目標數據。

[[199305]]

很多應用中都會有類似組織機構的表,組織機構的表又通常是典型的層次結構(沒有循環節點)。于是通過組織控制數據權限的時候,許多人都喜歡通過connect by獲得組織信息,然后再過濾目標數據。

在有些情況下,這樣寫并沒有什么問題,但有些情況下,這個就是一個大問題。

歸根結底,這是connect by特性導致的,Oracle無法知道connect by之后到底返回多少數據,所以有可能采取一些你所不期望的算法,結果自然不是你所期望的---非常慢。

下面,我就討論在Oracle 12.1.0.2中如果遇到這樣的語句應該如何處理。

為了很好理解,我做了3表:

執行SQL:

  1. SELECT A.CI, A.ENBAJ02 AS CELL_NAME 
  2.   FROM TDL_CM_CELL A, T_ORG_CELL_SCOPE S 
  3.  WHERE S.REGION_NAME = A.REGION_NAME 
  4.   AND S.CITY_NAME = A.CITY_NAME 
  5.   AND (S.ORG_ID) IN (SELECT ID 
  6.                         FROM T_ORG O 
  7.                       START WITH ID = 101021003 --1010210   
  8.                       --START WITH ID=1 
  9.                       CONNECT BY PARENT_ID = PRIOR ID) 

實際使用的執行計劃:

而不會采用自適應計劃(adaptive plan):

  1.  Plan Hash Value  : 2596385940  
  2.  
  3. ------------------------------------------------------------------------------------------------------------------- 
  4. | Id  | Operation                                       | Name                  | Rows | Bytes  | Cost | Time     | 
  5. ------------------------------------------------------------------------------------------------------------------- 
  6. |   0 | SELECT STATEMENT                                |                       | 2622 | 228114 |  227 | 00:00:01 | 
  7. |   1 |   NESTED LOOPS                                  |                       | 2622 | 228114 |  227 | 00:00:01 | 
  8. |   2 |    NESTED LOOPS                                 |                       | 2622 | 228114 |  227 | 00:00:01 | 
  9. | * 3 |     HASH JOIN                                   |                       |    1 |     31 |    7 | 00:00:01 | 
  10. |   4 |      VIEW                                       | VW_NSO_1              |    1 |     13 |    4 | 00:00:01 | 
  11. |   5 |       HASH UNIQUE                               |                       |    1 |     20 |    4 | 00:00:01 | 
  12. | * 6 |        CONNECT BY NO FILTERING WITH SW (UNIQUE) |                       |      |        |      |          | 
  13. |   7 |         TABLE ACCESS FULL                       | T_ORG                 |   75 |    825 |    3 | 00:00:01 | 
  14. |   8 |      TABLE ACCESS FULL                          | T_ORG_CELL_SCOPE      |   85 |   1530 |    3 | 00:00:01 | 
  15. | * 9 |     INDEX RANGE SCAN                            | IDX_TDL_CM_CELL_SCOPE |  257 |        |    8 | 00:00:01 | 
  16. |  10 |    TABLE ACCESS BY INDEX ROWID                  | TDL_CM_CELL           | 2313 | 129528 |  220 | 00:00:01 | 
  17. ------------------------------------------------------------------------------------------------------------------- 
  18.  
  19. Predicate Information (identified by operation id): 
  20. ------------------------------------------ 
  21. * 3 - access("S"."ORG_ID"="ID"
  22. * 6 - access("PARENT_ID"=PRIOR "ID"
  23. * 6 - filter("ID"=101021003) 
  24. * 9 - access("S"."REGION_NAME"="A"."REGION_NAME" AND "S"."CITY_NAME"="A"."CITY_NAME"
  25.  
  26.  
  27. Notes 
  28. ----- 
  29. - This is an adaptive plan 

原因在于,oracle無法知道connect by之后的數量,所以只能認為是很大的量

--

有一種方式就是,就是使用提示來解決:

  1. SELECT /*+ no_merge(x) use_nl(a x) */ 
  2.   A.CI, A.ENBAJ02 AS CELL_NAME 
  3.    FROM TDL_CM_CELL A, 
  4.         (select s.city_name, s.region_name 
  5.            from T_ORG_CELL_SCOPE S 
  6.           WHERE (S.ORG_ID) IN 
  7.                 (SELECT ID 
  8.                    FROM T_ORG O 
  9.                   START WITH ID = 101021003 --1010210   
  10.                  --START WITH ID=1 
  11.                  CONNECT BY PARENT_ID = PRIOR ID) 
  12.           
  13.          ) x 
  14.   where x.REGION_NAME = A.REGION_NAME 
  15.     AND x.CITY_NAME = A.CITY_NAME 

這樣計劃就是:

  1. Plan Hash Value  : 37846894  
  2.  
  3. --------------------------------------------------------------------------------------------------------------------- 
  4. | Id   | Operation                                        | Name                  | Rows | Bytes  | Cost | Time     | 
  5. --------------------------------------------------------------------------------------------------------------------- 
  6. |    0 | SELECT STATEMENT                                 |                       | 2313 | 277560 |  227 | 00:00:01 | 
  7. |    1 |   NESTED LOOPS                                   |                       | 2313 | 277560 |  227 | 00:00:01 | 
  8. |    2 |    NESTED LOOPS                                  |                       | 2313 | 277560 |  227 | 00:00:01 | 
  9. |    3 |     VIEW                                         |                       |    1 |     64 |    7 | 00:00:01 | 
  10. |  * 4 |      HASH JOIN                                   |                       |    1 |     31 |    7 | 00:00:01 | 
  11. |    5 |       VIEW                                       | VW_NSO_1              |    1 |     13 |    4 | 00:00:01 | 
  12. |    6 |        HASH UNIQUE                               |                       |    1 |     20 |    4 | 00:00:01 | 
  13. |  * 7 |         CONNECT BY NO FILTERING WITH SW (UNIQUE) |                       |      |        |      |          | 
  14. |    8 |          TABLE ACCESS FULL                       | T_ORG                 |   75 |    825 |    3 | 00:00:01 | 
  15. |    9 |       TABLE ACCESS FULL                          | T_ORG_CELL_SCOPE      |   85 |   1530 |    3 | 00:00:01 | 
  16. | * 10 |     INDEX RANGE SCAN                             | IDX_TDL_CM_CELL_SCOPE |  257 |        |    8 | 00:00:01 | 
  17. |   11 |    TABLE ACCESS BY INDEX ROWID                   | TDL_CM_CELL           | 2313 | 129528 |  220 | 00:00:01 | 
  18. --------------------------------------------------------------------------------------------------------------------- 
  19.  
  20. Predicate Information (identified by operation id): 
  21. ------------------------------------------ 
  22. * 4 - access("S"."ORG_ID"="ID"
  23. * 7 - access("PARENT_ID"=PRIOR "ID"
  24. * 7 - filter("ID"=101021003) 
  25. * 10 - access("X"."REGION_NAME"="A"."REGION_NAME" AND "X"."CITY_NAME"="A"."CITY_NAME")  

如果一個應用的start id可能是一個很大的范圍,如果強制使用提示,也會出現問題,所以如果有這樣的應用,可以考慮使用oracle 12c的adaptive特性。

如果不行,就必須把不同范圍的查詢,定義為不同的功能提交給用戶。

責任編輯:武曉燕 來源: Linux社區
相關推薦

2010-04-20 15:58:15

Oracle 語句

2010-04-13 15:04:16

Oracle優化

2011-05-20 15:59:06

Oracle存儲Sql語句

2009-03-04 09:06:56

優化sqlOracle

2010-10-25 12:05:40

SYS_CONNECT

2010-04-12 10:53:07

Oracle SQL

2010-04-26 14:32:21

Oracle SQL

2010-10-28 14:02:00

oracle conn

2009-01-14 09:28:12

OracleSQL10g

2010-04-20 09:06:25

Oracle優化

2010-05-05 10:37:40

Oracle優化查詢

2011-06-27 16:26:39

Oracle優化器RBOCBO

2011-04-11 17:28:50

oracle存儲select語句

2010-10-27 15:03:47

Oracle with

2010-04-13 15:14:31

Oracle優化

2010-04-29 16:53:18

Oracle多表關聯

2010-10-27 11:25:13

ORACLE ROWN

2024-12-05 09:02:00

Pythonif?

2011-04-15 09:53:37

Oracle 10gSQL優化

2010-05-12 14:04:29

Oracle優化器
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品99久久久久久www | 国产欧美在线视频 | 亚洲视频中文字幕 | 成人性视频在线播放 | 日韩视频在线播放 | 亚洲高清中文字幕 | 国产探花在线观看视频 | 国产精品1 | 精品久久久久久亚洲国产800 | 91中文字幕| 欧美日韩中文国产一区发布 | 欧美日韩电影一区 | 蜜月aⅴ免费一区二区三区 99re在线视频 | 日韩一区中文字幕 | 国产yw851.c免费观看网站 | 午夜亚洲| 黄色一级大片在线免费看产 | 国产日韩精品久久 | 亚洲看片网站 | 国产日韩一区 | 免费一区二区三区 | 亚洲成人中文字幕 | 国产精品久久 | 国产精品久久久久久一区二区三区 | 一区二区三区av | 国产精品夜间视频香蕉 | 91精品国产综合久久久久久首页 | 久久99精品久久久久久琪琪 | 成人在线观看黄 | 国产成人av一区二区三区 | 国产精彩视频 | 亚洲天堂男人的天堂 | 免费黄色片在线观看 | 亚洲第一福利网 | 久久综合九色综合欧美狠狠 | 日韩网站在线观看 | 国产羞羞视频在线观看 | 欧美午夜一区 | 国产色爽 | 色婷婷久久综合 | 精品91久久 |