Oracle 执行计划查看方法汇总及优劣对比

在 Oracle 数据库中,查看执行计划是优化 SQL 语句性能的重要工具。以下是几种常用的查看执行计划的方法及其优劣比较:

1. 使用 EXPLAIN PLAN FORDBMS_XPLAN.DISPLAY

方法
  1. 执行 EXPLAIN PLAN FOR 语句

    EXPLAIN PLAN FOR
    SELECT * FROM your_table WHERE your_column = 'some_value';
    
  2. 查看执行计划

    SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY);
    
优点
  • 简单易用:适用于大多数情况,操作简单。
  • 详细信息:可以提供详细的执行计划信息,包括操作类型、成本、行数等。
缺点
  • 不反映实际执行EXPLAIN PLAN 只是模拟执行计划,不一定反映实际执行情况。
  • 需要权限:需要 EXPLAIN PLAN 权限。

2. 使用 DBMS_XPLAN.DISPLAY_CURSOR

方法
  1. 执行 SQL 语句

    SELECT * FROM your_table WHERE your_column = 'some_value';
    
  2. 查看执行计划

    SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_CURSOR(NULL, NULL, 'ALLSTATS LAST'));
    
优点
  • 反映实际执行:查看的是实际执行的计划,更能反映真实的性能情况。
  • 详细统计信息:可以提供实际的执行统计信息,如 I/O 次数、CPU 时间等。
缺点
  • 需要执行 SQL:必须先执行 SQL 语句,才能查看执行计划。
  • 依赖共享池:只能查看在共享池中的 SQL 语句的执行计划。

3. 使用 AUTOTRACE(仅限 SQL*Plus)

方法
  1. 启用 AUTOTRACE

    SET AUTOTRACE ON EXPLAIN;
    
  2. 执行 SQL 语句

    SELECT * FROM your_table WHERE your_column = 'some_value';
    
  3. 禁用 AUTOTRACE

    SET AUTOTRACE OFF;
    
优点
  • 集成在 SQL*Plus:适用于 SQL*Plus 用户,操作简便。
  • 即时反馈:执行 SQL 语句时立即显示执行计划。
缺点
  • 仅限 SQL*Plus:只能在 SQL*Plus 中使用。
  • 功能有限:不如 DBMS_XPLAN.DISPLAY 提供的信息详细。

4. 使用 V$SQL_PLAN 视图

方法
  1. 找到 SQL 语句的 SQL_ID

    SELECT sql_id, sql_text FROM v$sql WHERE sql_text LIKE '%your_sql_statement%';
    
  2. 查询执行计划

    SELECT * FROM v$sql_plan WHERE sql_id = 'your_sql_id';
    
优点
  • 灵活性高:可以直接查询视图,灵活度高。
  • 实时信息:可以查看当前正在执行的 SQL 语句的执行计划。
缺点
  • 复杂性:需要手动查询视图,操作相对复杂。
  • 信息冗余:返回的信息较多,需要筛选有用的部分。

5. 使用 Oracle Enterprise Manager (OEM)

方法
  1. 登录 OEM
  2. 导航到 SQL 性能页面
  3. 输入 SQL 语句并查看执行计划
优点
  • 图形界面:提供图形化的用户界面,易于理解和操作。
  • 综合信息:可以查看多种性能指标,不仅仅是执行计划。
缺点
  • 需要 OEM:需要安装和配置 Oracle Enterprise Manager。
  • 资源消耗:图形界面可能消耗更多系统资源。

6. 使用 DBMS_XPLAN.DISPLAY_AWR

方法
  1. 找到 SQL 语句的 SQL_ID 和 PLAN_HASH_VALUE

    SELECT sql_id, plan_hash_value FROM dba_hist_sqlstat WHERE sql_text LIKE '%your_sql_statement%';
    
  2. 查询执行计划

    SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_AWR('your_sql_id', 'your_plan_hash_value'));
    
优点
  • 历史信息:可以查看 AWR 中的历史执行计划,有助于长期性能分析。
  • 详细统计:提供详细的执行统计信息。
缺点
  • 需要 AWR:需要 AWR 功能开启,且需要相应的权限。
  • 复杂性:操作相对复杂,需要查找 SQL_ID 和 PLAN_HASH_VALUE。

7. 使用事件 10046 跟踪

方法
  1. 启用事件 10046 跟踪

    • 对于当前会话:

      ALTER SESSION SET EVENTS '10046 trace name context forever, level 12';
      
    • 对于特定的会话(假设 SID 为 123,SERIAL# 为 456):

      EXEC DBMS_SYSTEM.SET_SQL_TRACE_IN_SESSION(123, 456, TRUE);
      
  2. 执行 SQL 语句

    SELECT * FROM your_table WHERE your_column = 'some_value';
    
  3. 禁用事件 10046 跟踪

    • 对于当前会话:

      ALTER SESSION SET EVENTS '10046 trace name context off';
      
    • 对于特定的会话(假设 SID 为 123,SERIAL# 为 456):

      EXEC DBMS_SYSTEM.SET_SQL_TRACE_IN_SESSION(123, 456, FALSE);
      
  4. 查看跟踪文件

    • 查找跟踪文件的位置,通常在

      user_dump_dest
      

      参数指定的目录下。

      SHOW PARAMETER user_dump_dest
      
    • 使用

      tkprof
      

      工具格式化跟踪文件:

      tkprof trace_file.trc output_file.txt explain=your_username/your_password
      
    • 查看生成的 output_file.txt 文件,其中包含详细的执行计划和性能信息。

优点
  • 详细信息:提供详细的执行计划、执行时间和等待事件等信息,有助于深入分析性能问题。
  • 灵活性:可以针对特定的会话或当前会话启用跟踪。
  • 历史信息:可以保留长时间的跟踪信息,便于后续分析。
缺点
  • 性能开销:启用跟踪会增加系统开销,特别是在高负载情况下。
  • 复杂性:操作相对复杂,需要手动启用和禁用跟踪,以及使用 tkprof 格式化跟踪文件。
  • 文件管理:需要管理和清理生成的跟踪文件,以免占用过多磁盘空间。

8. 使用 STATISTICS_LEVEL=ALL

方法
  1. 设置统计级别为 ALL

    ALTER SESSION SET STATISTICS_LEVEL=ALL;
    
  2. 执行 SQL 语句

    SELECT * FROM your_table WHERE your_column = 'some_value';
    
  3. 查看执行计划和统计信息

    SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_CURSOR(NULL, NULL, 'ALLSTATS LAST'));
    
优点
  • 详细统计信息:可以提供详细的执行计划和统计信息,包括 I/O 次数、CPU 时间等。
  • 反映实际执行:查看的是实际执行的计划,更能反映真实的性能情况。
  • 操作简单:只需设置统计级别并执行 SQL 语句即可。
缺点
  • 性能开销:设置 STATISTICS_LEVELALL 会增加执行 SQL 语句的性能开销。
  • 临时设置:仅对当前会话有效,需要在每个会话中手动设置。

总结

方法优点缺点
EXPLAIN PLAN FOR + DBMS_XPLAN.DISPLAY简单易用,详细信息不反映实际执行,需要权限
DBMS_XPLAN.DISPLAY_CURSOR反映实际执行,详细统计信息需要执行 SQL,依赖共享池
AUTOTRACE集成在 SQL*Plus,即时反馈仅限 SQL*Plus,功能有限
V$SQL_PLAN灵活性高,实时信息复杂性高,信息冗余
Oracle Enterprise Manager (OEM)图形界面,综合信息需要 OEM,资源消耗
DBMS_XPLAN.DISPLAY_AWR历史信息,详细统计需要 AWR,复杂性
事件 10046 跟踪详细信息,灵活性高,历史信息性能开销,复杂性,文件管理
ALTER SESSION SET STATISTICS_LEVEL=ALL详细统计信息,反映实际执行,操作简单性能开销,临时设置

适用场景

  • EXPLAIN PLAN FOR + DBMS_XPLAN.DISPLAY:适用于简单的查询优化,快速查看执行计划。
  • DBMS_XPLAN.DISPLAY_CURSOR:适用于已经执行的 SQL 语句,需要查看实际执行情况。
  • AUTOTRACE:适用于 SQL*Plus 用户,需要快速反馈。
  • V$SQL_PLAN:适用于需要灵活查询执行计划的场景。
  • Oracle Enterprise Manager (OEM):适用于需要图形化界面和综合性能信息的场景。
  • DBMS_XPLAN.DISPLAY_AWR:适用于需要查看历史执行计划的场景。
  • 事件 10046 跟踪:适用于需要深入分析性能问题,特别是涉及执行时间和等待事件的场景。
  • STATISTICS_LEVEL=ALL:适用于需要详细统计信息和反映实际执行情况的场景,操作简单但有性能开销。

希望这些方法和优劣比较对你有所帮助!

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

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

相关文章

基于Springboot的流浪宠物管理系统

基于javaweb的流浪宠物管理系统 介绍 基于javaweb的流浪宠物管理系统的设计与实现,后端框架使用Springbootmybatis,前端框架使用Vuehrml,数据库使用mysql,使用B/S架构实现前台用户系统和后台管理员系统,和不同权限级别…

unity 绿幕抠图

1.硬件:Insta360 Link 2C摄像机 2.引用shader Shader "Demo/ChromaKey" { Properties { _MainTex("Texture", 2D) "white" {} _KeyColor("KeyColor", Color) (0,1,0,0) _TintColor(&q…

Linux中离线安装gcc

gcc在安装一些其他工具的经常用到,在此记录下如何安装gcc。 1.在线安装 yum -y install gcc 2.离线安装 2.1 获取安装包链接: https://pan.baidu.com/s/1oDvt64ByWs1w-evz5TXU7w?pwd9cfo mpfr-3.1.1-4.el7.x86_64.rpmlibmpc-1.0.1-3.el7.x86_64.rp…

继续完善wsl相关内容:基础指令

文章目录 前言一、我们需要安装wsl,这也是安装docker desktop的前提,因此我们在这篇文章里做了介绍:二、虽然我们在以安装docker desktop为目的时,不需要安装wsl的分发(distribution),但是装一个分发也是有诸多好处的:三、在使用wsl时,不建议把东西直接放到系统里,因…

GITEX GLOBAL聚焦AI创新,Soul App创始人张璐团队带来多模态社交新体验

2024年10月,全球瞩目的科技盛会GITEX GLOBAL在迪拜举行。作为全球三大IT展之一,GITEX GLOBAL一直是展示全球尖端科技的重要平台,今年吸引了全球超6700家科技企业及创新公司参展。 在此次展会中,Soul App创始人张璐团队携自主研发的多模态大模型首次在国际大型展会亮相,展示了其…

C++——map相关的oj题

前言:菜鸟写博客给自己看,我是菜鸟。 1:随机链表的复制 1.1题目要求: 1.2解题思路: 可以分两步来实现代码: ①先将示例1链表中的val值以及next的指向关系深拷贝到另一个新的链表当中 ②再处理新链表中&am…

go web单体项目 学习总结

为什么学习go 博主的主语言是Java,目前的工作也是做Java web开发,有了Java的经验后就想着再学一门语言,其实有两个原因,第一是基于兴趣,也想和Java对比下到底有什么不同,在学习go的时候让我更加了解了Java…

paimon的四种changelog模式(2)-none模式

# 请先了解input模式 环境创建 CREATE CATALOG fs_catalog WITH (typepaimon,warehousefile:/data/soft/paimon/catalog );USE CATALOG fs_catalog;drop table if exists t_changelog_none ;CREATE TABLE t_changelog_none (age BIGINT,money BIGINT,hh STRING,PRIMARY KEY (h…

新型大语言模型的预训练与后训练范式,阿里Qwen

前言:大型语言模型(LLMs)的发展历程可以说是非常长,从早期的GPT模型一路走到了今天这些复杂的、公开权重的大型语言模型。最初,LLM的训练过程只关注预训练,但后来逐步扩展到了包括预训练和后训练在内的完整…

NAT:连接私有与公共网络的关键技术(4/10)

一、NAT 的工作原理 NAT 技术的核心功能是将私有 IP 地址转换为公有 IP 地址,使得内部网络中的设备能够与外部互联网通信。其工作原理主要包括私有 IP 地址到公有 IP 地址的转换、端口号映射以及会话表维护这几个步骤。 私有 IP 地址到公有 IP 地址的转换&#xff1…

notepad++文件github下载

1、github下载网址:Releases notepad-plus-plus/notepad-plus-plus GitHub 2、找到操作系统支持的软件: 3、CSDN下载链接:https://download.csdn.net/download/u013083576/90046203

【AI绘画】Midjourney进阶:色调详解(下)

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: AI绘画 | Midjourney 文章目录 💯前言💯Midjourney中的色彩控制为什么要控制色彩?为什么要在Midjourney中控制色彩? 💯色调纯色调灰色调暗色调 &#x1f4af…

【MySQL篇】持久化和非持久化统计信息的深度剖析(第一篇,总共六篇)

💫《博主介绍》:✨又是一天没白过,我是奈斯,DBA一名✨ 💫《擅长领域》:✌️擅长Oracle、MySQL、SQLserver、阿里云AnalyticDB for MySQL(分布式数据仓库)、Linux,也在扩展大数据方向的知识面✌️…

PH热榜 | 2024-11-27

DevNow 是一个精简的开源技术博客项目模版,支持 Vercel 一键部署,支持评论、搜索等功能,欢迎大家体验。 在线预览 1. Agentplace 标语:这是一个能创建互动式AI网站和应用的平台。 介绍:Agentplace是一个平台&#xf…

ffmpeg 增亮 docker 使用

使用最新的 docker pull jrottenberg/ffmpeg docker run -it --rm -v /path/to/input:/input -v /path/to/output:/output jrottenberg/ffmpeg <ffmpeg command>比如我想增亮 在 /home 目录下 有一个 video.mp4 docker run --rm -v /home:/home jrottenberg/ffmpeg:7…

单片机学习笔记 11. 外部中断

更多单片机学习笔记&#xff1a;单片机学习笔记 1. 点亮一个LED灯单片机学习笔记 2. LED灯闪烁单片机学习笔记 3. LED灯流水灯单片机学习笔记 4. 蜂鸣器滴~滴~滴~单片机学习笔记 5. 数码管静态显示单片机学习笔记 6. 数码管动态显示单片机学习笔记 7. 独立键盘单片机学习笔记 8…

【PyTorch】(基础一)----pytorch环境搭建

PyTorch环境搭建 该系列笔记主要参考了小土堆的视频教程&#xff0c;传送门&#xff1a;P1. PyTorch环境的配置及安装&#xff08;Configuration and Installation of PyTorch)【PyTorch教程】_哔哩哔哩_bilibili PyTorch 是一个开源的机器学习库&#xff0c;主要用 Python 编…

uniapp开发支付宝小程序自定义tabbar样式异常

解决方案&#xff1a; 这个问题应该是支付宝基础库的问题&#xff0c;除了依赖于官方更新之外&#xff0c;开发者可以利用《自定义 tabBar》曲线救国 也就是创建一个空内容的自定义tabBar&#xff0c;这样即使 tabBar 被渲染出来&#xff0c;但从视觉上也不会有问题 1.官方文…

YOLOv11融合PIDNet中的PagFM模块及相关改进思路

YOLOv11v10v8使用教程&#xff1a; YOLOv11入门到入土使用教程 YOLOv11改进汇总贴&#xff1a;YOLOv11及自研模型更新汇总 《PIDNet: A Real-time Semantic Segmentation Network Inspired by PID Controllers》 一、 模块介绍 论文链接&#xff1a;https://arxiv.org/pdf/2…

NSCTF 做题笔记

[GWCTF 2019]pyre 下载附件&#xff0c;是一个pyc文件。 转换为py文件。 在用vscode打开。 分析源码。源码就是进行了异或和数值转换。 有一点很坑&#xff0c;凑得中的值要转换为ASCII值否则就是一串乱码。 编写脚本&#xff1a; #include<iostream> #include<s…