如果要了解执行计划和执行顺序,必须理解执行计划的父子关系。执行计划是一个树状结构,顶层的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),所以这个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的步骤,就完成了本语句的执行。
分享到:
相关推荐
为了更好地理解和优化 Oracle 数据库的执行计划,我们需要了解执行计划的生成过程、优化方法和执行计划的解读方法。 执行计划生成过程 执行计划的生成过程可以分为四个步骤: 1. 解析:判断对象是否存在,是否有...
可以显示执行计划对应执行顺序的工具包
xplan 包是是对DMBS_XPLAN包的扩展,可以执行显示SQL语句的执行顺序(有一个ORDER列表示)。
在测试过程中,日志文件(如 `testLog.txt`)通常用于记录规则的执行过程,帮助开发者调试和理解规则执行的顺序和效果。对于大型项目,良好的日志记录和分析是至关重要的,可以帮助定位问题,优化性能,并确保业务...
多线程有很好的并发性即无序性,在某些特殊情况...这里提供了一种类似Task顺序执行多线程的实现(可能跟Task的原理有很大区别),希望对大家能有帮助,对此类问题的实现有更好的思路和技巧的同学欢迎留言,大家一起探讨。
KingbaseES V8R3 执行计划详解是数据库管理和优化的重要工具,它为数据库管理员提供了深入理解SQL查询如何在数据库内部执行的详细信息。执行计划是数据库系统根据查询语句生成的一种操作序列,用于高效地获取和处理...
- ID相同:执行顺序由上至下。 - ID不同:如果是子查询,ID值越大,优先级越高,越先被执行。 - ID相同又不同:可以认为是一组,从上往下顺序执行;在所有组中,ID值越大,优先级越高,越先执行。 - **select_...
### SQL语句执行顺序说明 #### 一、SQL语句准备执行阶段 当SQL语句进入Oracle的库缓存后,为了确保其能够被正确执行,Oracle会经历一系列的检查和准备过程。这一阶段主要涉及以下几个步骤: 1. **语法检查**:...
例如,对于一条从SALES和PRODUCTS表中选择产品类别平均销售额的SQL查询语句,生成的执行计划会展示出全表扫描、哈希连接、哈希聚合等操作符的使用和顺序。这样的执行计划有助于开发者理解数据库是如何具体操作来满足...
在这里,我们可以看到,执行计划的每个步骤都有其对应的成本、Cardinality 和 Bytes 等信息。执行计划的顺序是从上到下,从左到右。 Oracle 执行计划是 Oracle 数据库在执行查询语句时所采取的访问路径的表示。了解...
在Oracle数据库中,可以通过多种方式来查看和收集执行计划。例如,使用`EXPLAIN PLAN FOR`命令来生成执行计划,并使用`DBMS_XPLAN.DISPLAY`过程来查看该计划。此外,还可以通过自动工作负载仓库 (AWR) 或SQL Tuning ...
在更复杂的应用场景中,`java.util.concurrent`包下的工具如`ExecutorService`、`Future`和`Callable`接口也可以帮助我们管理和控制任务的执行顺序。例如,可以使用`ExecutorService`提交`Callable`任务,然后通过`...
Oralce 19c执行计划调优学习笔记 1_执行计划.pdf 2_explain plan for.pdf 3_dbms_xplan.display_cursor.pdf 4_执行计划顺序.pdf 5_直方图.pdf
2. 在同一级如果某个动作有子 ID,就需要查看子 ID 的执行顺序。 例如,一个简单的执行计划示例如下: Query Plan ----------------------------------------- SELECT STATEMENT [CHOOSE] Cost=1234 TABLE ACCESS ...
6. **使用OPTION (FORCE ORDER)**:控制执行计划中操作符的顺序。 #### 七、总结 理解和优化SQL Server执行计划对于提高数据库性能至关重要。通过对执行计划的深入分析,我们可以发现潜在的问题并采取措施加以改进...
Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序Sql语句执行顺序
### MySQL执行计划详解 在数据库查询优化领域,理解MySQL执行计划是至关重要的技能之一。...通过深入分析执行计划,数据库管理员和开发人员可以识别并解决潜在的性能瓶颈,从而提升系统的整体响应速度和用户体验。