Oracle中connect by语句的优化

很多应用中都会有类似组织机构的语句表,组织机构的语句表又通常是典型的层次结构(没有循环节点)。于是语句通过组织控制数据权限的时候,许多人都喜欢通过connect by获得组织信息,语句然后再过滤目标数据。语句
在有些情况下,语句这样写并没有什么问题,语句但有些情况下,语句这个就是语句一个大问题。
归根结底,语句这是语句connect by特性导致的企商汇,Oracle无法知道connect by之后到底返回多少数据,语句所以有可能采取一些你所不期望的语句算法,结果自然不是语句你所期望的---非常慢。
下面,语句我就讨论在Oracle 12.1.0.2中如果遇到这样的语句应该如何处理。
为了很好理解,我做了3表:
执行SQL:
SELECT A.CI, A.ENBAJ02 AS CELL_NAME FROM TDL_CM_CELL A, T_ORG_CELL_SCOPE S WHERE S.REGION_NAME = A.REGION_NAME AND S.CITY_NAME = A.CITY_NAME AND (S.ORG_ID) IN (SELECT ID FROM T_ORG O START WITH ID = 101021003 --1010210 --START WITH ID=1 CONNECT BY PARENT_ID = PRIOR ID)实际使用的执行计划:

而不会采用自适应计划(adaptive plan):
Plan Hash Value : 2596385940 ------------------------------------------------------------------------------------------------------------------- | Id | Operation | Name | Rows | Bytes | Cost | Time | ------------------------------------------------------------------------------------------------------------------- | 0 | SELECT STATEMENT | | 2622 | 228114 | 227 | 00:00:01 | | 1 | NESTED LOOPS | | 2622 | 228114 | 227 | 00:00:01 | | 2 | NESTED LOOPS | | 2622 | 228114 | 227 | 00:00:01 | | * 3 | HASH JOIN | | 1 | 31 | 7 | 00:00:01 | | 4 | VIEW | VW_NSO_1 | 1 | 13 | 4 | 00:00:01 | | 5 | HASH UNIQUE | | 1 | 20 | 4 | 00:00:01 | | * 6 | CONNECT BY NO FILTERING WITH SW (UNIQUE) | | | | | | | 7 | TABLE ACCESS FULL | T_ORG | 75 | 825 | 3 | 00:00:01 | | 8 | TABLE ACCESS FULL | T_ORG_CELL_SCOPE | 85 | 1530 | 3 | 00:00:01 | | * 9 | INDEX RANGE SCAN | IDX_TDL_CM_CELL_SCOPE | 257 | | 8 | 00:00:01 | | 10 | TABLE ACCESS BY INDEX ROWID | TDL_CM_CELL | 2313 | 129528 | 220 | 00:00:01 | ------------------------------------------------------------------------------------------------------------------- Predicate Information (identified by operation id): ------------------------------------------ * 3 - access("S"."ORG_ID"="ID") * 6 - access("PARENT_ID"=PRIOR "ID") * 6 - filter("ID"=101021003) * 9 - access("S"."REGION_NAME"="A"."REGION_NAME" AND "S"."CITY_NAME"="A"."CITY_NAME") Notes ----- - This is an adaptive plan原因在于,oracle无法知道connect by之后的数量,所以只能认为是很大的量
--
有一种方式就是亿华云计算,就是使用提示来解决:
SELECT /*+ no_merge(x) use_nl(a x) */ A.CI, A.ENBAJ02 AS CELL_NAME FROM TDL_CM_CELL A, (select s.city_name, s.region_name from T_ORG_CELL_SCOPE S WHERE (S.ORG_ID) IN (SELECT ID FROM T_ORG O START WITH ID = 101021003 --1010210 --START WITH ID=1 CONNECT BY PARENT_ID = PRIOR ID) ) x where x.REGION_NAME = A.REGION_NAME AND x.CITY_NAME = A.CITY_NAME这样计划就是:
Plan Hash Value : 37846894 --------------------------------------------------------------------------------------------------------------------- | Id | Operation | Name | Rows | Bytes | Cost | Time | --------------------------------------------------------------------------------------------------------------------- | 0 | SELECT STATEMENT | | 2313 | 277560 | 227 | 00:00:01 | | 1 | NESTED LOOPS | | 2313 | 277560 | 227 | 00:00:01 | | 2 | NESTED LOOPS | | 2313 | 277560 | 227 | 00:00:01 | | 3 | VIEW | | 1 | 64 | 7 | 00:00:01 | | * 4 | HASH JOIN | | 1 | 31 | 7 | 00:00:01 | | 5 | VIEW | VW_NSO_1 | 1 | 13 | 4 | 00:00:01 | | 6 | HASH UNIQUE | | 1 | 20 | 4 | 00:00:01 | | * 7 | CONNECT BY NO FILTERING WITH SW (UNIQUE) | | | | | | | 8 | TABLE ACCESS FULL | T_ORG | 75 | 825 | 3 | 00:00:01 | | 9 | TABLE ACCESS FULL | T_ORG_CELL_SCOPE | 85 | 1530 | 3 | 00:00:01 | | * 10 | INDEX RANGE SCAN | IDX_TDL_CM_CELL_SCOPE | 257 | | 8 | 00:00:01 | | 11 | TABLE ACCESS BY INDEX ROWID | TDL_CM_CELL | 2313 | 129528 | 220 | 00:00:01 | --------------------------------------------------------------------------------------------------------------------- Predicate Information (identified by operation id): ------------------------------------------ * 4 - access("S"."ORG_ID"="ID") * 7 - access("PARENT_ID"=PRIOR "ID") * 7 - filter("ID"=101021003) * 10 - access("X"."REGION_NAME"="A"."REGION_NAME" AND "X"."CITY_NAME"="A"."CITY_NAME")如果一个应用的start id可能是一个很大的范围,如果强制使用提示,也会出现问题,所以如果有这样的应用,可以考虑使用oracle 12c的adaptive特性。
如果不行,就必须把不同范围的查询,定义为不同的功能提交给用户。香港云服务器
相关文章
一体机系统重装教程(简明易懂的一体机系统重装步骤,帮你重拾流畅体验)
摘要:当一体机的操作系统出现严重崩溃或运行缓慢的情况时,重新安装系统是一种常见的解决方法。然而,对于不了解如何进行一体机系统重装的用户来说,这可能会是一个相当困难的任务。本文将向您详细介...2025-11-05轻松上手快启PE,实现一键装机(快速学习和使用快启PE,节省装机时间和工作量)
摘要:在现代科技的发展下,电脑已经成为我们日常生活中不可或缺的一部分。然而,随着时间的推移和使用频率的增加,电脑会出现各种各样的问题,如系统崩溃、病毒感染等,这时候就需要重新安装操作系统...2025-11-05台式电脑设置U盘启动教程(简明易懂的U盘启动指南,让你的台式电脑焕发新生)
摘要:随着科技的发展,U盘启动成为了重装系统或修复故障的常用方法。本文将为大家介绍如何在台式电脑上设置U盘启动,帮助你轻松解决电脑相关问题。1.准备所需材料和工具——U盘、可供下...2025-11-05魔箭机械键盘的强劲性能与出色用户体验(领先的游戏键盘技术为你带来超乎想象的操作体验)
摘要:随着电子竞技的兴起,机械键盘成为了许多游戏玩家必备的装备之一。魔箭机械键盘以其卓越的性能和出色的用户体验,成为了众多玩家追捧的对象。本文将深入探讨魔箭机械键盘的各个方面,为读者展现...2025-11-05- 摘要:如今,在办公环境中,Windows操作系统已成为最为常用的电脑系统之一。掌握Windows的操作技巧,对提升办公效率、提高工作质量至关重要。本文将为大家提供一份全面指南,帮助读者深...2025-11-05
如何快速恢复消失的任务栏(任务栏不见了,怎么办?一键恢复教程)
摘要:任务栏是Windows操作系统中常用的工具栏,用于快速启动应用程序、查看通知和控制系统设置。然而,有时候任务栏可能会意外消失或隐藏起来,让人感到困惑和不便。本文将介绍一些简单而有效...2025-11-05

最新评论