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

数据库 Oracle
以下的文章主要是以Ocacle执行计划与执行顺序的实际应用代码的形式来引出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种常用的关闭方式
责任编辑:佚名 来源: 博客园
相关推荐

2009-11-10 16:00:05

Oracle执行计划

2011-09-14 17:03:17

数据库执行计划解析

2022-08-15 15:09:26

SQL数据库MySQL

2021-03-17 09:35:51

MySQL数据库explain

2015-04-22 14:17:45

SQL SERVERMSSQL SERVE缓冲区

2023-09-21 10:55:51

MysqlSQL语句

2021-05-28 10:46:36

MySQL执行计划

2020-09-15 08:44:57

MySQL慢日志SQL

2009-11-13 16:28:02

Oracle生成执行计

2024-09-12 15:16:14

2022-08-08 08:03:44

MySQL数据库CBO

2022-12-13 08:36:42

D-SMARTOracle数据库

2022-02-15 07:36:21

SQLEXPLAIN数据库

2021-09-07 10:43:25

EverDB分布式执行

2021-02-20 08:40:19

HiveExplain底层

2021-04-24 12:01:08

MySQL数据库Mysql执行计划

2009-11-18 17:05:47

捕获Oracle SQ

2011-08-18 14:10:51

Oracle不走索引

2024-04-19 13:17:40

PostgreSQLSQL数据库

2010-10-27 15:26:42

Oracle执行计划
点赞
收藏

51CTO技术栈公众号