如果要了解执行计划和执行顺序,必须理解执行计划的父子关系。执行计划是一个树状结构,顶层的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的步骤,就完成了本语句的执行。
分享到:
相关推荐
2. 访问顺序:确定访问存储器的顺序,例如先访问索引还是先访问表。 获取执行计划的方式有多种,常见的方式包括: 1. 使用 Explain 语句:使用 Explain 语句可以生成执行计划,例如: ```sql explain plan set ...
为了更好地理解和优化 Oracle 数据库的执行计划,我们需要了解执行计划的生成过程、优化方法和执行计划的解读方法。 执行计划生成过程 执行计划的生成过程可以分为四个步骤: 1. 解析:判断对象是否存在,是否有...
可以显示执行计划对应执行顺序的工具包
标题 "Drools 规则执行顺序" 涉及的是一个业务规则引擎——Drools 的核心概念。Drools 是一个开源的Java决策管理平台,它允许开发者使用规则语言来编写业务逻辑,这些规则可以按特定顺序执行,以处理复杂的业务场景...
xplan 包是是对DMBS_XPLAN包的扩展,可以执行显示SQL语句的执行顺序(有一个ORDER列表示)。
* 访问顺序:指定了 Oracle 访问存储器的顺序,例如从左到右、从右到左等。 三、获取执行计划的方式 有多种方式可以获取执行计划,包括: * Explain 语句:使用 Explain 语句可以获取执行计划,例如:Explain ...
- **顺序**:执行步骤的顺序,显示了数据如何被处理和返回。 5. **索引的影响**: 索引可以显著提升查询速度,但不是所有查询都能从索引中受益。执行计划会显示是否使用了索引,以及是全索引扫描还是索引查找。 ...
- ID相同:执行顺序由上至下。 - ID不同:如果是子查询,ID值越大,优先级越高,越先被执行。 - ID相同又不同:可以认为是一组,从上往下顺序执行;在所有组中,ID值越大,优先级越高,越先执行。 - **select_...
6. **使用OPTION (FORCE ORDER)**:控制执行计划中操作符的顺序。 #### 七、总结 理解和优化SQL Server执行计划对于提高数据库性能至关重要。通过对执行计划的深入分析,我们可以发现潜在的问题并采取措施加以改进...
多线程有很好的并发性即无序性,在某些特殊情况...这里提供了一种类似Task顺序执行多线程的实现(可能跟Task的原理有很大区别),希望对大家能有帮助,对此类问题的实现有更好的思路和技巧的同学欢迎留言,大家一起探讨。
KingbaseES V8R3 执行计划详解是数据库管理和优化的重要工具,它为数据库管理员提供了深入理解SQL查询如何在数据库内部执行的详细信息。执行计划是数据库系统根据查询语句生成的一种操作序列,用于高效地获取和处理...
以下是一些基本的执行顺序: 1. **FROM子句**:首先处理FROM子句,确定需要操作的表或视图。Oracle从右向左处理表名,最后一个表名为驱动表。如果连接多个表,数据量较小的表应该放在后面,这样可以减少中间结果集...
执行计划揭示了Oracle如何处理一个SQL查询,包括数据的访问路径、使用的索引、排序方式以及表之间的连接顺序等。本文将深入探讨如何查看执行计划,并提供优化SQL的策略。 一、执行计划的概念 执行计划是Oracle...
SQL(Structured Query Language)是一种用于管理关系型数据库的标准语言,其查询原理和执行顺序对于数据库性能优化至关重要。本文将深入探讨SQL查询的执行过程,帮助读者理解如何构建高效查询。 #### SQL语句执行...
当同时出现了where_group_by_having_order_by的时候_执行顺序和编写顺序时的用法
在Oracle数据库中,可以通过多种方式来查看和收集执行计划。例如,使用`EXPLAIN PLAN FOR`命令来生成执行计划,并使用`DBMS_XPLAN.DISPLAY`过程来查看该计划。此外,还可以通过自动工作负载仓库 (AWR) 或SQL Tuning ...
例如,对于一条从SALES和PRODUCTS表中选择产品类别平均销售额的SQL查询语句,生成的执行计划会展示出全表扫描、哈希连接、哈希聚合等操作符的使用和顺序。这样的执行计划有助于开发者理解数据库是如何具体操作来满足...
在这里,我们可以看到,执行计划的每个步骤都有其对应的成本、Cardinality 和 Bytes 等信息。执行计划的顺序是从上到下,从左到右。 Oracle 执行计划是 Oracle 数据库在执行查询语句时所采取的访问路径的表示。了解...
### MySQL执行计划详解 在数据库查询优化领域,理解MySQL执行计划是至关重要的技能之一。...通过深入分析执行计划,数据库管理员和开发人员可以识别并解决潜在的性能瓶颈,从而提升系统的整体响应速度和用户体验。