`

执行计划和执行顺序

阅读更多

 

    如果要了解执行计划和执行顺序,必须理解执行计划的父子关系。执行计划是一个树状结构,顶层的STATEMENT是这棵树的根。父子关系按照如下的树状结构组织:

PARENT

FIRST  CHILD

SECOND CHILD

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

PARENT1

FIRST  CHILD

FIRST  GRANDCHILD

SECOND CHILD

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

set autotrace traceonly explain

select ename,dname  from emp, dept 

where emp.deptno=dept.deptno 

and dept.dname in

 (‘ACCOUNTING’,’RESEARCH’,’SALES’,’OPERATIONS’);

15 rows selected.

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

Execution Plan

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

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

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

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

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

 

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

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

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

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

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

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

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

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

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

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

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

分享到:
评论

相关推荐

    oracle 执行计划 详解

    为了更好地理解和优化 Oracle 数据库的执行计划,我们需要了解执行计划的生成过程、优化方法和执行计划的解读方法。 执行计划生成过程 执行计划的生成过程可以分为四个步骤: 1. 解析:判断对象是否存在,是否有...

    看懂执行计划之执行顺序-XPLAN包

    可以显示执行计划对应执行顺序的工具包

    查看执行计划顺序包

    xplan 包是是对DMBS_XPLAN包的扩展,可以执行显示SQL语句的执行顺序(有一个ORDER列表示)。

    Drools规则执行顺序

    在测试过程中,日志文件(如 `testLog.txt`)通常用于记录规则的执行过程,帮助开发者调试和理解规则执行的顺序和效果。对于大型项目,良好的日志记录和分析是至关重要的,可以帮助定位问题,优化性能,并确保业务...

    C# 不使用Task实现的多线程顺序执行

    多线程有很好的并发性即无序性,在某些特殊情况...这里提供了一种类似Task顺序执行多线程的实现(可能跟Task的原理有很大区别),希望对大家能有帮助,对此类问题的实现有更好的思路和技巧的同学欢迎留言,大家一起探讨。

    KingbaseES V8R3 执行计划详解.docx

    KingbaseES V8R3 执行计划详解是数据库管理和优化的重要工具,它为数据库管理员提供了深入理解SQL查询如何在数据库内部执行的详细信息。执行计划是数据库系统根据查询语句生成的一种操作序列,用于高效地获取和处理...

    mysql 索引与执行计划

    - ID相同:执行顺序由上至下。 - ID不同:如果是子查询,ID值越大,优先级越高,越先被执行。 - ID相同又不同:可以认为是一组,从上往下顺序执行;在所有组中,ID值越大,优先级越高,越先执行。 - **select_...

    SQL语句执行顺序说明

    ### SQL语句执行顺序说明 #### 一、SQL语句准备执行阶段 当SQL语句进入Oracle的库缓存后,为了确保其能够被正确执行,Oracle会经历一系列的检查和准备过程。这一阶段主要涉及以下几个步骤: 1. **语法检查**:...

    oracle执行计划详解

    例如,对于一条从SALES和PRODUCTS表中选择产品类别平均销售额的SQL查询语句,生成的执行计划会展示出全表扫描、哈希连接、哈希聚合等操作符的使用和顺序。这样的执行计划有助于开发者理解数据库是如何具体操作来满足...

    怎样看懂Oracle的执行计划

    在这里,我们可以看到,执行计划的每个步骤都有其对应的成本、Cardinality 和 Bytes 等信息。执行计划的顺序是从上到下,从左到右。 Oracle 执行计划是 Oracle 数据库在执行查询语句时所采取的访问路径的表示。了解...

    执行计划收集与分析

    在Oracle数据库中,可以通过多种方式来查看和收集执行计划。例如,使用`EXPLAIN PLAN FOR`命令来生成执行计划,并使用`DBMS_XPLAN.DISPLAY`过程来查看该计划。此外,还可以通过自动工作负载仓库 (AWR) 或SQL Tuning ...

    控制台展示执行顺序

    在更复杂的应用场景中,`java.util.concurrent`包下的工具如`ExecutorService`、`Future`和`Callable`接口也可以帮助我们管理和控制任务的执行顺序。例如,可以使用`ExecutorService`提交`Callable`任务,然后通过`...

    Oralce 19c执行计划调优学习笔记

    Oralce 19c执行计划调优学习笔记 1_执行计划.pdf 2_explain plan for.pdf 3_dbms_xplan.display_cursor.pdf 4_执行计划顺序.pdf 5_直方图.pdf

    oracle执行计划解读

    2. 在同一级如果某个动作有子 ID,就需要查看子 ID 的执行顺序。 例如,一个简单的执行计划示例如下: Query Plan ----------------------------------------- SELECT STATEMENT [CHOOSE] Cost=1234 TABLE ACCESS ...

    解剖SQL执行计划

    6. **使用OPTION (FORCE ORDER)**:控制执行计划中操作符的顺序。 #### 七、总结 理解和优化SQL Server执行计划对于提高数据库性能至关重要。通过对执行计划的深入分析,我们可以发现潜在的问题并采取措施加以改进...

    sql语句的顺序是怎么执行的

    Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序

    mysql文档执行计划

    ### MySQL执行计划详解 在数据库查询优化领域,理解MySQL执行计划是至关重要的技能之一。...通过深入分析执行计划,数据库管理员和开发人员可以识别并解决潜在的性能瓶颈,从而提升系统的整体响应速度和用户体验。

Global site tag (gtag.js) - Google Analytics