ORACAL执行计划

概述

| Id  | Operation              | Name                  | Rows  | Bytes | TempSpc | Cost (%CPU) | Time     |
-----------------------------------------------------------------------------------
| 0   | SELECT STATEMENT       |                       | 10000 | 120000| 0       | 20000 (100)| 00:00:01 |
| 1   | SORT AGGREGATE         |                       | 1     | 120   |          | 20000 (100)|          |
| 2   | INDEX FAST FULL SCAN   | IDX_Employee_LastName | 10000 | 120000| 0       | 10000  (10)|          |解释:
| Id  | - 表示执行计划的步骤编号,从0开始,按执行顺序递增。
| Operation | - 描述数据库执行的具体操作类型,如:SELECT STATEMENT、SORT AGGREGATE、INDEX FULL SCAN等。
| Name      | - 操作所涉及的对象名称,如索引名、表名等。
| Rows      | - 预估的执行此操作将读取或产生的行数,是Oracle优化器根据统计信息做出的估算。
| Bytes     | - 预估处理的字节数,反映了操作所需处理的数据量。
| TempSpc   | - 指定此步骤是否会使用临时段(临时空间),如果是,显示所需的临时空间大小(单位通常是KB)。
| Cost (%CPU)| - 执行此步骤的总成本估计,包括CPU成本和I/O成本,用于衡量不同执行计划的相对代价。
| Time      | - 预测的执行时间,但通常在实际运行中会有差异,主要用于优化器决策。举例说明:
第一行表示整个SQL语句(SELECT STATEMENT),预估处理10000行数据,总共120000字节,总成本是20000(其中100%是CPU成本),预计耗时1秒。
第二行是一个排序聚合操作(SORT AGGREGATE),生成1行结果,共120字节。
第三行是一个索引快速全扫描(INDEX FAST FULL SCAN),同样处理10000行数据,总成本较低,使用索引IDX_Employee_LastName进行扫描,不需要临时空间。

使用方式

EXPLAIN PLAN FOR 查询语句

ID(每个流程的唯一标识):

ID(Id)列代表了执行计划中不同操作步骤的唯一标识符。
即:每个流程的唯一标识

Operation(具体操作,执行顺序):

“Operation”列展示了数据库为了执行SQL语句而采取的不同操作步骤。这些操作涵盖了从数据源访问、过滤、排序、连接、聚合等多种数据库内部处理行为
1:执行的操作
2:执行的顺序(缩进越多,越先执行)
同一级的动作执行时遵循最上最右先执行的原则

可能会出现操作明细

1. SELECT STATEMENT:

    • 整个查询的起点,标识SQL语句的整体执行计划。

2. 全表扫描:TABLE ACCESS FULL:

    • 全表扫描,即对整个表的所有数据进行线性读取,没有利用任何索引。

3. 索引扫描:INDEX SCAN:

    • 索引扫描,包括但不限于:
      • INDEX RANGE SCAN: 根据索引范围条件检索数据。
      • INDEX UNIQUE SCAN: 当唯一索引被用来直接定位一行数据时。
      • INDEX FAST FULL SCAN: 对索引进行类似全表扫描的操作,但比全表扫描可能更快,因为它可能避免了额外的排序和行链接操作。

4. 排序:SORT:

    • 排序操作,例如:
      • SORT ORDER BY
      • SORT GROUP BY: 对数据进行分组前的排序。
      • SORT AGGREGATE: 聚合操作,如SUM、COUNT、AVG等,可能伴随排序。

5. 表连接方式:JOIN:

    • 表连接操作,例如:
a. 嵌套循环连接:小表连大表:NESTED LOOPS JOIN: 最常见的连接类型之一。
工作原理: 嵌套循环连接是最基础的连接方法,它的工作原理类似于嵌套循环,外层循环逐行遍历一个表,内层循环则针对每一行去另一个表中查找匹配的记录。其性能很大程度上依赖于内外表的大小以及索引的有效性。性能特点:当外表较小或者内外表之间有很好的索引关联时(如外表通过主键连接内表的唯一索引),嵌套循环连接效率非常高。
若外表庞大而内表没有合适的索引,或者连接条件没有利用到索引,这种连接方式可能会很慢,因为它可能需要进行大量的索引查找或全表扫描。
b. 合并连接(内存不足用这个):排序好的表进行连接:MERGE JOIN: ,适用于已经排序或者部分排序的数据。
工作原理: 合并连接要求两个表都已经排序好(或者可以利用现有索引达到排序效果),然后将两个排序好的数据流进行合并,匹配相同的键值来进行连接。合并连接可以有效地利用索引和排序,无需额外的临时空间。
性能特点:
● 当两个表都很大,但都已排序或可以利用索引进行有效的排序时,合并连接效率很高。
● 如果数据量巨大,内存不足以一次性装入所有数据,但有足够的磁盘空间和合理的I/O速度,合并连接可以通过多轮排序和合并逐步完成,性能较好。
c. HASH JOIN: 使用哈希算法来匹配两表之间的记录。

6. 哈希连接(HASH JOIN)

工作原理: 哈希连接首先将一方表构建哈希表,然后扫描另一方表,对每一行计算哈希值并查找哈希表,通过哈希索引快速找到匹配项。哈希连接需要足够的内存来存储哈希表。
性能特点:
● 当两个表都非常大,并且内存充足时,哈希连接通常比嵌套循环连接更快,因为它避免了大量索引查找操作。
● 如果内存不足,哈希连接可能需要溢出到磁盘,这会显著降低性能,但即使如此,有时仍可能比其他连接方式更快,尤其是在大规模数据处理中。
总结起来,选择哪种连接方式最为高效,通常取决于表的大小、索引的存在和有效性、内存资源、磁盘I/O能力等因素。在实际应用中,Oracle数据库的优化器会根据统计信息和成本模型自动选择最优的连接方式。在特定场景下,也可能需要通过手工hints等方式指导优化器选择合适的连接方法。

7. 过滤:FILTER:

    • 过滤操作,应用于WHERE子句中的条件筛选。

8. INDEX SKIP SCAN:

    • 索引跳跃扫描,仅读取索引的一部分来满足查询需求。

9. 分区操作:PARTITION RANGE ALL / SINGLE / ITERATOR:

    • 分区表相关的扫描操作,针对分区表中的特定分区或所有分区。

10. 视图操作:VIEW:

    • 视图操作,数据库处理视图逻辑的方式。

11. rowID查询:TABLE ACCESS BY INDEX ROWID:

    • 通过索引获取行地址(ROWID),随后进行单行的表访问。

每一个“Operation”都是SQL执行流程中的一个阶段,Oracle优化器会选择成本最低的执行路径来执行SQL语句,从而尽可能提高查询效率。通过分析执行计划中的Operation序列,可以深入了解数据库是如何实际处理SQL查询请求的,并据此进行性能优化。

备注:表的访问方式

● 全表扫描table access full

  • Oracle 会读取表中所有的行,并检查每一行是否满足 where 限制条件
  • 全表扫描时可以使用多块读(一次 I/O 读取多块数据块)操作,提升吞吐量

● rowid 扫描table access by rowid(单行存取他最快)

  • rowid:伪列,Oracle 自带的,不会存储 rowid 的值,不能被增、删、改
  • 一旦一行数据插入后,则其对应的 rowid 在该行的生命周期内是唯一的,即使发生行迁移,该行的 rowid 值也不变

简述:查询时,先找索引树,根据索引树存储的rowid信息,拿到rowid对应的行。

rowid简述:行的唯一ID。(还包含有关数据在数据库物理存储结构中的具体位置信息。)

● 索引扫描table access by index scan

索引唯一扫描:index unique scan(主键唯一索引专用,只返回一条数据)
  • 每次至多返回一条记录
  • 有下列两种情况(当查询字段有下列约束时)
    • unique (唯一索引)
    • primary key (主键ID)
索引范围扫描:index range scan(携带范围条件会用他)
  • 每次至少返回一条记录
  • 一般有下列三种情况
    • 在唯一索引列上使用了范围操作符(如:> < >= <= between)
    • 在组合索引上,只使用部分列进行查询(查询时必须包含前导列,否则会走全表扫描)
    • 对非唯一索引列上进行的任何查询

索引全表扫描:index full scan

扫描索引并排序返回

索引快速扫描:index fast full scan

扫描索引 不 排序返回

索引跳跃扫描(组合索引专用):index skip scan
  • 必须是 组合索引
  • 除了前导列(索引中第一列)外的其他列作为条件

说明了:MYSQL不允许打破的规则被ORACAL打破了 (本人的理解)

ABC为联合索引,

MYSQL:可用:A,AB,ABC

ORACAL:A,AB,ABC,AC,BC

NAME(每个步骤涉及的表名,索引名等)

"Name"列通常表示的是执行计划中涉及的具体数据库对象,例如表名、索引名、视图名或者是其他类型的数据库对象,如分区、物化视图等。每个操作步骤(Operation)都会关联到一个或多个数据库对象,"Name"列就用来展示这些操作所作用的具体对象。
| Id  | Operation          | Name                 |
-------------------------------------------------
|   1 | TABLE ACCESS FULL  | Customers            |
|   2 | INDEX RANGE SCAN   | PK_Products          |
|   3 | SORT JOIN          |                      |
|   4 | TABLE ACCESS BY INDEX ROWID| Orders |
  • 在第一个操作步骤中,"Name"是"Customers",表示执行了一个全表扫描操作在"Customers"表上。
  • 第二个步骤使用了名为"PK_Products"的索引进行了索引范围扫描。
  • 第四个步骤使用索引行ID访问了"Orders"表,这里的"Name"为空是因为该步骤是通过前面的索引扫描间接访问的。

通过分析执行计划中的"Name"列,我们可以清楚地了解到数据库执行SQL语句时访问的具体数据来源,这对于性能调优和理解查询执行过程至关重要。

Rows(操作预计涉及的行数)

K是千

M是万

Bytes(预计处理的数据量)

TempSpc(临时表)

存在此行,说明使用临时表,展示的是临时表占用的内存。

不存在此行,说明未使用临时表

Cost (%CPU) (预计CPU使用情况)

Cost (%CPU)列表示Oracle优化器对执行某个操作预计耗费的CPU成本的度量。这个成本不仅包括CPU时间,还包括内存和I/O操作的成本,但通常以CPU时间作为主要参考基准。Cost (%CPU)列的值是一个相对成本,用于比较不同执行计划的成本,从而帮助优化器选择成本最低的执行计划。

| Id  | Operation          | Name                 | Rows  | Bytes | Cost (%CPU) |
----------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   |                     |  1000 |  8000 |   10000 (1) |
|   1 |  SORT AGGREGATE    |                     |     1 |    12 |    1000 (1) |
|   2 |   TABLE ACCESS FULL| Employees            |  1000 |  8000 |    1000 (1) |

在这个例子中:

  • Id 为 2 的 TABLE ACCESS FULL 操作预计的总成本是 1000 (1),这意味着Oracle估计执行全表扫描 Employees 表大概会花费相当于1000个CPU单位的工作量,其中 (1) 表示大致的CPU成本占比为100%。
  • Id 为 1 的 SORT AGGREGATE 操作预计的成本是 1000 (1),这表示排序和聚合操作大约需要1000个CPU单位的工作量。
  • Id 为 0 的 SELECT STATEMENT 总体成本是 10000 (1),这是整个查询的预计总成本,包括子操作的成本。

优化器会综合考虑Cost (%CPU)以及其他因素(如Rows、Bytes、TempSpc等)来确定最佳执行计划,旨在选择成本最低且能最快得到查询结果的方案。但要注意,实际运行时的成本可能会与预估成本有所出入,因为预估是基于当前的统计信息和Oracle的优化算法得出的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/802854.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

adb remount

区别 权限 adb remount后push的文件可以获得更高的系统权限&#xff0c;remount操作会将文件系统挂载为可读写模式&#xff0c;可以将文件推送到系统分区&#xff0c;修改系统文件等。直接push的文件只能放在用户可访问的位置&#xff0c;无法修改系统文件。 文件位置 通过…

你对加班是怎么看的

做为一名互联网从业者,不管是开发人员或者是测试人员,都逃不开加班这个话题。虽然简历中并不建议过多表现自己多么能加班,但写简历之前就要对加班有自己的看法,把这些意识融入到简历中去。 1 产生加班的原因 第一种是工作经验较少,业务不熟练,导致正常工作时间无法完成任…

如何在Python中实现设计模式?

如何在Python中实现设计模式&#xff1f; 设计模式是在软件开发中解决常见问题的最佳实践。它们提供了在特定上下文中对软件设计的重复使用性解决方案。Python&#xff0c;作为一种灵活且强大的编程语言&#xff0c;非常适合实现各种设计模式。下面&#xff0c;我将介…

多线程 线程池 Task

多线程概念&#xff1f;优点及缺点&#xff1f; 多线程是指程序中包含多个执行流&#xff08;线程&#xff09;&#xff0c;即在一个程序中可以同时运行多个不同的线程来执行不同的任务&#xff0c;也就是说允许单个程序创建多个并行执行的线程来完成各自的任务。 概括&#x…

手写简易操作系统(二十五)--文件系统第三部分

前情提要 一、文件写入 1.1、file的写入 文件写入比较复杂&#xff0c;函数行数相当多 /*** description: 把buf中的count个字节写入file,成功则返回写入的字节数,失败则返回-1 * param {file*} file 文件* param {void*} buf 缓存* param {uint32_t} count 写入的字节数…

leetcode2009--使数组连续的最少操作数

1. 题意 给定一个数组&#xff0c;求最少的操作数使得数组连续。 每次操作你可选择一个数&#xff0c;将它变为任意其他数。 leetcode2009 2. 题解 思路&#xff1a;反向考虑&#xff0c;最多能保留多少个数字使得当前数组连续。 就变成了 [ x , x s z − 1 ] [x,xsz-1]…

基于Java+SpringBoot+Vue民宿预约管理系统(源码+文档+部署+讲解)

一.系统概述 随着社会的不断进步与发展&#xff0c;人们经济水平也不断的提高&#xff0c;于是对各行各业需求也越来越高。利用计算机网络来处理各行业事务这一概念更深入人心&#xff0c;由于工作繁忙以及其他的原因&#xff0c;到实体店进行预约也是比较难实施的。如果开发一…

es6新增加的语法

let和const关键字&#xff1a;let和const允许你声明具有块级作用域的变量和常量。这有助于避免使用var时可能出现的变量提升和全局污染问题。模板字符串&#xff1a;使用反引号()可以创建多行字符串和嵌入表达式。 javascript let name world; let greeting Hello, ${name}!…

迪拜公司怎么注册 迪拜公司注册优势 迪拜公司注册条件

一、迪拜公司注册优势 1、税收优势&#xff1a;迪拜是一个没有个人所得税、企业所得税和增 值税的地区&#xff0c;这为注册公司在迪拜提供了巨大的税收优势。 2、地理位置优势&#xff1a;迪拜位于东西方和南北方的交汇点&#xff0c;拥有得天独厚的地理位置。这使得迪拜成为…

LLM Agents调研

LLM Agents调研 1、从 Copilot 到 Agent2、Agent概述3、agent框架2.1 框架介绍2.2框架对比 4、应用场景3.1single-agent应用3.2multi-agent 应用 5、agent功能选型参考&#xff1a; 1、从 Copilot 到 Agent 参考&#xff1a;https://mp.weixin.qq.com/s/vVUO-WRkp8FS3wKcfgu45…

【Vue3 + ElementUI】表单校验无效(写法:this.$refs[‘formName‘].validate((valid) =>{} ))

一. 表单校验 1.1 template模块 el-form 中 若校验&#xff0c;ref 和 rules 必须要有 <template><div style"padding:20px"><el-form ref"formName" :model"form" :rules"formRules" label-width"120px"…

C++进阶之路---何为智能指针?

顾得泉&#xff1a;个人主页 个人专栏&#xff1a;《Linux操作系统》 《C从入门到精通》 《LeedCode刷题》 键盘敲烂&#xff0c;年薪百万&#xff01; 一、为什么需要智能指针&#xff1f; 下面我们先分析一下下面这段程序有没有什么内存方面的问题&#xff1f;提示一下&am…

AI技术的创业机会

AI技术创业有哪些机会&#xff1f; 人工智能&#xff08;AI&#xff09;技术作为当今科技创新的前沿领域&#xff0c;为创业者提供了广阔的机会和挑战。随着AI技术的快速发展和应用领域的不断拓展&#xff0c;未来AI技术方面会有哪些创业机会呢&#xff1f; 方向一&#xff1a…

Spring 之 IoC基于XML管理Bean

1. 环境搭建 参考我之前的笔记&#xff1a; Spring6 基础入门-CSDN博客 2. 获取Bean的方式 2.1 根据Id 获取 参考之前的笔记&#xff1a; Spring6 基础入门-CSDN博客 Testpublic void testGetBeanById(){//加载spring配置文件ApplicationContext context new ClassPathXmlA…

医疗图像分割 | 基于Pyramid-Vision-Transformer算法实现医疗息肉分割

项目应用场景 面向医疗图像息肉分割场景&#xff0c;项目采用 Pytorch Pyramid-Vision-Transformer 深度学习算法来实现。 项目效果 项目细节 > 具体参见项目 README.md (1) 模型架构 (2) 项目依赖&#xff0c;包括 python 3.8、pytorch 1.7.1、torchvision 0.8.2(3) 下载…

粤嵌教育:继续坚持诚信为本,分享合理投诉小妙招

在如今的教育市场中&#xff0c;诚信已经成为一个不可忽视的关键词。粤嵌教育作为一家有着深厚教育背景和丰富教学经验的培训机构&#xff0c;始终坚持诚信为本&#xff0c;以优质的教学服务赢得了广大学员和社会的认可。然而&#xff0c;在教育行业中&#xff0c;难免会遇到一…

C++:Stmt预处理SQL与大文件存取(五)

1、预处理相关API mysql_stmt_init&#xff1a;初始化生成一个预编译处理的Stmt对象mysql_stmt_prepare&#xff1a;预处理SQL语句&#xff0c;值部分用&#xff1f;进行占位&#xff08;可以防止SQL注入&#xff09;mysql_stmt_bind_param&#xff1a;给预处理的SQL语句中的&…

数据仓库实践

什么是数据仓库&#xff1f; 数据仓库是一个用于存储大量数据并支持数据分析与报告的系统。它通常用于集成来自不同来源的数据&#xff0c;提供一个统一的视图&#xff0c;以便进行更深入的分析和决策。 数据仓库的主要优势&#xff1f; 决策支持&#xff1a;为企业决策提供可靠…

渗透知识贴

文章目录 基础知识同源策略 常见web漏洞SQL注入漏洞 web中间件 基础知识 同源策略 同源策略是目前所有浏览器都实行的一种安全政策。A网页设置的 Cookie&#xff0c;B网页不能打开&#xff0c;除非这两个网页同源。所谓同源&#xff0c;是指&#xff1a;协议、端口、域名相同…

Windows Server 2008添加Web服务器(IIS)、WebDAV服务、网络负载均衡

一、Windows Server 2008添加Web服务器&#xff08;IIS&#xff09; &#xff08;1&#xff09;添加角色&#xff0c;搭建web服务器&#xff08;IIS&#xff09; &#xff08;2&#xff09;添加网站&#xff0c;关闭默认网页&#xff0c;添加默认文档 在客户端浏览器输入服务器…