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执行计划和执行顺序的内容介绍,望你能有所收获。

网站题目:Ocacle执行计划与执行顺序的代码示例
当前网址:http://www.shufengxianlan.com/qtweb/news11/536511.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联