数据库Oracle数据库执行计划的步骤顺序_Oracle数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

数据库Oracle执行计划的步骤顺序

作者:黑客防线网安Oracle维护基地 来源:黑客防线网安Oracle维护基地 浏览次数:0

本篇关键词:Oracle数据库Oracle教程
黑客防线网安网讯:   如果要了解执行计划和执行顺序,必须理解执行计划的父子关系。执行计划是一个树状结构,顶层的STATEMENT是这棵树的根。父子关系按照如下的树状结构组织:  PARENT  FIRST CHILD  ...
   如果要了解执行计划和执行顺序必须理解执行计划的父子关系执行计划是一个树状结构顶层的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的步骤,就完成了本语句的执行。
  ---------------------------------------------------------------------------------------------------------------------------------
  有同事问我如何看执行计划的执行顺序。这个问题我想很多朋友都会不屑一顾的,这么简单的问题,谁不会看?
  但是这里我还是想说一说我是怎样看执行计划的执行顺序的。
  我看执行计划的执行顺序的原则就是先从最开头一直往右看,直到看到最右边的并列的地方,对于不并列的,靠右的先执行;如果见到并列的,就从上往下看,对于并列的,靠上的先执行。
  好了,我们以上述原则来看一个实例:
  SQL*Plus: Release 10.2.0.1.0 - Prod
    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-13087-1.html
网站维护教程更新时间:2012-03-23 00:50:32  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer