暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 19C SQL行源生成

原创 Asher.HU 2021-02-04
971


行源发生器是从优化器接收最佳执行计划,并产生一个迭代执行计划是由数据库的其余部分可用软件。

迭代计划是一个二进制程序,当由SQL引擎执行时,将生成结果集。该计划采取步骤组合的形式。每个步骤都会返回一个行集下一步要么使用此集合中的行,要么最后一步将行返回给发出SQL语句的应用程序。

行源是通过在执行计划与可以迭代地处理该行的控制结构沿一个步骤中返回的行集。行源可以是表,视图或联接或分组操作的结果。

行源生成器生成一个行源树,该是行源的集合。行源树显示以下信息:

  • 语句引用的表的顺序
  • 语句中提到的每个表的访问方法
  • 语句中受联接操作影响的表的联接方法
  • 数据操作,例如过滤,排序或聚合

示例3-1执行计划

本示例显示了启用SELECT语句执行计划AUTOTRACE该语句为姓氏以字母开头的所有雇员选择姓氏,职务和部门名称A该语句的执行计划是行源生成器的输出。

SELECT e.last_name, j.job_title, d.department_name 
FROM   hr.employees e, hr.departments d, hr.jobs j
WHERE  e.department_id = d.department_id
AND    e.job_id = j.job_id
AND    e.last_name LIKE 'A%';
 
Execution Plan
----------------------------------------------------------
Plan hash value: 975837011

--------------------------------------------------------------------------------
| Id| Operation                     | Name        |Rows|Bytes|Cost(%CPU)|Time  |
--------------------------------------------------------------------------------
| 0 | SELECT STATEMENT              |             |  3 | 189 | 7(15)| 00:00:01 |
|*1 |  HASH JOIN                    |             |  3 | 189 | 7(15)| 00:00:01 |
|*2 |   HASH JOIN                   |             |  3 | 141 | 5(20)| 00:00:01 |
| 3 |    TABLE ACCESS BY INDEX ROWID| EMPLOYEES   |  3 |  60 | 2 (0)| 00:00:01 |
|*4 |     INDEX RANGE SCAN          | EMP_NAME_IX |  3 |     | 1 (0)| 00:00:01 |
| 5 |    TABLE ACCESS FULL          | JOBS        | 19 | 513 | 2 (0)| 00:00:01 |
| 6 |   TABLE ACCESS FULL           | DEPARTMENTS | 27 | 432 | 2 (0)| 00:00:01 |
--------------------------------------------------------------------------------
 
Predicate Information (identified by operation id):
---------------------------------------------------
 
   1 - access("E"."DEPARTMENT_ID"="D"."DEPARTMENT_ID")
   2 - access("E"."JOB_ID"="J"."JOB_ID")
   4 - access("E"."LAST_NAME" LIKE 'A%')
       filter("E"."LAST_NAME" LIKE 'A%')
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论