热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

oracle递归查询性能优化,关于子查询,递归循环的效率问题

本帖最后由gongcheng28于2012-4-1014:48编辑--Createtablecreatetablemaster_info(masteridvarchar2(32),

本帖最后由 gongcheng28 于 2012-4-10 14:48 编辑

-- Create table

create table master_info

(

masterid       varchar2(32),

parent         varchar2(32)

);

alter table master_info

add constraint UK01_master_info unique (masterid);

-- Create/Recreate indexes

create index I01_master_info on master_info (parent);

-- Create table

create table detail_info

(

masterid       varchar2(32),

sons           varchar2(32)

);

-- Create/Recreate indexes

create index I01_detail_info on detail_info (masterid);

create index I02_detail_info on detail_info (sons);

第一种写法:

select *

from (select b.sons,

c.parent

from detail_info b inner join master_info c

on c.masterid = b.masterid

) m

start with m.parent = '1'

connect by m.parent = prior m.sons

第二种写法:

select b.sons,

c.parent

from detail_info b inner join master_info c

on c.masterid = b.masterid

start with c.parent = '1'

connect by c.parent = prior b.sons

两种写法在数据量少的时候的执行计划是一样的。

PLAN_TABLE_OUTPUT

--------------------------------------------------------------------------------

Plan hash value: 1480042955

--------------------------------------------------------------------------------

| Id  | Operation                      | Name            | Rows  | Bytes | Cost

--------------------------------------------------------------------------------

|   0 | SELECT STATEMENT               |                 |     2 |    72 |     4

|*  1 |  CONNECT BY WITH FILTERING     |                 |       |       |

|   2 |   NESTED LOOPS                 |                 |       |       |

|   3 |    NESTED LOOPS                |                 |     1 |    72 |     1

|   4 |     TABLE ACCESS BY INDEX ROWID| MASTER_INFO     |     1 |    36 |     1

|*  5 |      INDEX RANGE SCAN          | I01_MASTER_INFO |     1 |       |     1

|*  6 |     INDEX RANGE SCAN           | I01_DETAIL_INFO |     1 |       |     0

|   7 |    TABLE ACCESS BY INDEX ROWID | DETAIL_INFO     |     1 |    36 |     0

|   8 |   NESTED LOOPS                 |                 |     1 |    90 |     1

|   9 |    NESTED LOOPS                |                 |     1 |    54 |     1

|  10 |     CONNECT BY PUMP            |                 |       |       |

|  11 |     TABLE ACCESS BY INDEX ROWID| MASTER_INFO     |     1 |    36 |     0

|* 12 |      INDEX RANGE SCAN          | I01_MASTER_INFO |     1 |       |     0

|  13 |    TABLE ACCESS BY INDEX ROWID | DETAIL_INFO     |     1 |    36 |     0

|* 14 |     INDEX RANGE SCAN           | I01_DETAIL_INFO |     1 |       |     0

PLAN_TABLE_OUTPUT

--------------------------------------------------------------------------------

--------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

1 - access("C"."PARENT"=PRIOR "B"."SONS")

5 - access("C"."PARENT"='1')

6 - access("C"."MASTERID"="B"."MASTERID")

12 - access("C"."PARENT"="connect$_by$_pump$_004"."prior b.sons  ")

14 - access("C"."MASTERID"="B"."MASTERID")

Note

-----

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

但是当数据量有几十万的时候,第一种写法的执行计划,直接变成,三张表都是full_scan了。

这个数据量小的时候,和数据量大的时候的执行计划,差别也太大了。



推荐阅读
  • 本文介绍了游标的使用方法,并以一个水果供应商数据库为例进行了说明。首先创建了一个名为fruits的表,包含了水果的id、供应商id、名称和价格等字段。然后使用游标查询了水果的名称和价格,并将结果输出。最后对游标进行了关闭操作。通过本文可以了解到游标在数据库操作中的应用。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • 欢乐的票圈重构之旅——RecyclerView的头尾布局增加
    项目重构的Git地址:https:github.comrazerdpFriendCircletreemain-dev项目同步更新的文集:http:www.jianshu.comno ... [详细]
  • 开发笔记:select from具体执行相关知识介绍及案例分析
    本文由编程笔记小编整理,主要介绍了select from具体执行相关的知识,包括数据插入、查询最小rowID、查询每个重复名字的最小rowID、删除重复数据等操作,并提供了案例分析。希望对读者有一定的参考价值。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 这篇文章主要介绍了Python拼接字符串的七种方式,包括使用%、format()、join()、f-string等方法。每种方法都有其特点和限制,通过本文的介绍可以帮助读者更好地理解和运用字符串拼接的技巧。 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
author-avatar
颖子_忒美
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有