Ocacle执行计划与执行顺序的代码示例

我们如果想要了解,Ocacle执行计划与执行顺序,就必须的理解Ocacle执行计划的关系。其实Ocacle执行计划的关系就好比父子关系,执行计划通俗的讲,就是一个树状结构,顶层的STATEMENT是这棵树的根。父子关系按照如下的树状结构组织:

 

  1. PARENT   
  2. FIRST CHILD   
  3. SECOND CHILD   

 

在这个例子里,FIRST CHILD最先执行,然后是SECOND CHILD,这两个步骤执行完毕后,执行PARENT。下面是一个更多层次的结构:

 

  1. PARENT1   
  2. FIRST CHILD   
  3. FIRST GRANDCHILD   
  4. SECOND CHILD   

 

FIRST GRANDCHILD是第一个执行的步骤,然后是FIRST CHILD。下面通过一个真实的Ocacle执行计划来验证这个原则:

 

  1. set autotrace traceonly explain   
  2. select ename,dname from emp, dept   
  3. where emp.deptno=dept.deptno   
  4. and dept.dname in  
  5. (‘ACCOUNTING’,’RESEARCH’,’SALES’,’OPERATIONS’);   
  6. rows selected.   

 

这个语句的执行计划如下:

 

  1. Execution Plan  
  2. SELECT STATEMENT Optimizer=CHOOSE (Cost=3 Card=8 Bytes=248)   
  3. HASH JOIN (Cost=3 Card=8 Bytes=248)   
  4. TABLE ACCESS (FULL) OF ‘DEPT’ (Cost=1 Card=3 Bytes=36)   
  5. TABLE ACCESS (FULL) OF ‘EMP’ (Cost=1 Card=16 Bytes=304)   

 

 

注意这个Ocacle执行计划的最左边的两个列,第一个列是步骤的ID,第二个列是父步骤的ID。执行从ID=0的行开始:

0 SELECT STATEMENT Optimizer=CHOOSE (Cost=3 Card=8 Bytes=248)

这个步骤没有父步骤,有一个子步骤(ID=1),所以这个ID=1的步骤必须在执行步骤0之前执行。继续观察ID=1的步骤:

1 0 HASH JOIN (Cost=3 Card=8 Bytes=248)

这个步骤是ID=0的步骤的子步骤,该步骤有2个子步骤:ID=2和ID=3,因此ID=2和ID=3的步骤必须在ID=1的步骤之前执行。再来检查ID=2的步骤:

2 1 TABLE ACCESS (FULL) OF ‘DEPT’ (Cost=1 Card=3 Bytes=36)

这个步骤是ID=1的步骤的子步骤,并且该步骤没有任何子步骤。因此该步骤是这个SQL语句第一个执行的步骤,这个步骤产生的结果集会提供给ID=1的步骤。这个步骤是对表DEPT进行全表扫描,这个步骤的COST=1。

ID=1的步骤也依赖ID=3的步骤:

3 1 TABLE ACCESS (FULL) OF ‘EMP’ (Cost=1 Card=16 Bytes=304)

这个步骤是ID=1的步骤的第二个子步骤,没有任何子步骤,在这个语句中,是第二个被执行的步骤。

ID=1的步骤将ID=3和ID=3的步骤的结果集进行HASH 连接,然后把结果交给ID=0的步骤,就完成了本语句的执行。

以上的相关内容就是对Ocacle执行计划和执行顺序的内容介绍,望你能有所收获。

【编辑推荐】

  1. Oracle SQL的优化规则解析
  2. Oracle SQL的优化的规则描述
  3. Oracle存储过程的编写经验总结
  4. Oracle11g认证考试的3个主要途径
  5. Oracle数据库中3种常用的关闭方式

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/236888.html<

(0)
运维的头像运维
上一篇2025-04-22 05:35
下一篇 2025-04-22 05:36

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注