百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

详解六种方法查看oracle执行计划=》优化必备

sinye56 2024-10-04 11:01 5 浏览 0 评论

概述

很多时候我们去优化某条sql时,第一步通常是对sql做执行计划分析,看是走全扫还是索引扫描,是NL、SMJ还是HJ连接,是不是有绑定变量等等...今天不讲分析,主要讲怎么看执行计划。

下面介绍下几种常见的查看执行计划的方式(方法比较多,就不一一演示了)


1、 explain plan(类似plsql中的f5)

这里先使用explain plan命令对目标SQL做explain,在使用"select * from table(dbms_xplan.display)"查看上述使用explain plan命令后得到的执行计划。

PS:PL/SQL Developer中的快捷键F5就是在explain plan命令上的一层封装。

语法:explain plan for + SQL
select * from table(dbms_xplan.display)

优点:无需真正执行,快捷方便

缺点:

a. 没有输出运行时的相关统计信息(产生多少逻辑读,多少次递归调用,多少次物理读的情况)

b. 无法判断是处理了多少行

c. 无法判断表被访问了多少次

其他命令

#配合explain plan使用
select * from table(dbms_xplan.display);
#查看刚刚执行过的SQL的执行计划
select * from table(dbms_xplan.display_cursor(null,null,'advanced'));
#只要目标SQL的执行计划所在的Child Cursor没有被age out出Shared Pool
select sql_text,sql_id,hash_value,child_number from v$sql where sql_text like '%select * from emp%';
#用于查看指定SQL的执行计划
select * from table(dbms_xplan.display_cursor('sql_id/hash_value',child_cursor_number, 'advanced'));
#VERSION_COUNT代表有几种不同的执行计划
select sql_text,sql_id,hash_value,child_number from v$sql where sql_text like '%select * from emp%';
#查看指定SQL的所有历史执行计划,前提是该SQL的执行计划被采集到AWR Repository中
select * from table(dbms_xplan.display_awr('sql_id'));

2、SQLPLUS中的AUTOTRACE

语法:set autotrace on

类似的有:

Set autotrace on #(得到执行计划,输出运行结果)

Set autotrace traceonly #(得到执行计划,不输出运行结果)

Set autotrace traceonly explain #(得到执行计划,不输出运行结果和统计信息部分,仅展现执行计划部分)

Set autotrace traceonly statistics #(不输出运行结果和执行计划部分,仅展现统计信息部分)

优点:

a. 可以输出运行时的相关统计信息(产生多少逻辑读,多少次递归调用,多少次物理读的情况)

b. 虽然必须要等语句执行完毕后才可输出执行计划,但是可以有traceonly开关来控制返回结果不打屏输出

缺点:

a. 必须等到语句真正执行完毕后,才可以出结果

b. 无法看到表被访问了多少次


3、statistics_level=all

语法:

alter session setstatistics_level=all;
select * from table(dbms_xplan.display_cursor(null,null,'allstats last'));

注:

a. 如果用 /*+ gather_plan_statistics */的方法,可以省略alter session setstatistics_level=all;

b. 关键字解读:

Starts:该sql执行的次数。

E-Rows:执行计划预计的行数。

A-Rows:实际返回的行数。A-Rows跟E-Rows做比较,就可以确定哪一步执行计划出问题。

A-Time:每一步实际执行的时间(HH:MM:SS.FF),根据这一行可以知道该sql耗时在了哪个地方。

Buffers:每一步实际执行的逻辑读或一致性读。

Reads:物理读。

OMem:当前操作完成所有内存工作区(Work Aera)操作所总共使用私有内存(PGA)中工作区的大小,这个数据是由优化器统计数据以及前一次执行的性能数据估算得出的

1Mem:当工作区大小无法满足操作所需的大小时,需要将部分数据写入临时磁盘空间中(如果仅需要写入一次就可以完成操作,就称一次通过,One-Pass;否则为多次通过;Multi_Pass).该列数据为语句最后一次执行中,单次写磁盘所需要的内存大小,这个由优化器统计数据以及前一次执行的性能数据估算得出的

User-Mem:语句最后一次执行中,当前操作所使用的内存工作区大小,括号里面为(发生磁盘交换的次数,1次即为One-Pass,大于1次则为Multi_Pass,如果没有使用磁盘,则显示OPTIMAL)

OMem、1Mem为执行所需的内存评估值,0Mem为最优执行模式所需内存的评估值,1Mem为one-pass模式所需内存的评估值。0/1/M 为最优/one-pass/multipass执行的次数。Used-Mem耗的内存

优点:

a. 可以清晰的从starts得出表被访问多少

b. 可以清晰的从E-ROWS和A-ROWS中得到预测的行数和真实的行数,从而可以准确判断Oracle评估是否准确。

c. 虽然没有专门的输出运行时的相关统计信息,但是执行计划中的BUFFERS就是真实的逻辑读的多少

缺点:

a. 必须要等到语句真正执行完毕后,才可以出结果。

b. 无法控制记录输屏打出,不像autotrace有 traceonly 可以控制不将结果打屏输出。

c. 看不出递归调用的次数,看不出物理读的多少(不过逻辑读才是重点)


4、通过dbms_xplan.display_cursor输入sql_id参数直接获取

语法:

select * from table(dbms_xplan.display_cursor('&sq_id')); #从共享池获取

注:

a. select * fromtable(dbms_xplan.display_awr('&sq_id')); 从awr性能视图获取

b. 查看多个sql的执行计划

select * from table(dbms_xplan.display_cursor('4jj76r0vw14zx',0));

select * fromtable(dbms_xplan.display_cursor('4jj76r0vw14zx',1));

优点:

a. 知道sql_id立即可得到执行计划,和explain plan for 一样无需执行;

b. .可以得到真实的执行计划。

缺陷

a. 没有输出运行时的相关统计信息(产生多少逻辑读,多少次递归调用,多少次物理读的情况);

b. 无法判断是处理了多少行;

c. 无法判断表被访问了多少次。


5、10046事件

与之前三种查看执行计划方法不同之处在于,所得到的执行计划中明确显示了目标SQL实际执行计划中每一个执行步骤所消耗的逻辑读、物理读和花费的时间。执行计划与明细资源消耗会写入此Session所对应的trace文件中,Oracle会在参数USER_DUMP_DEST所代表的目录下生成这个trace文件。

  • 首先在当前Session中激活10046事件
  • 接着在此Session中执行目标SQL
  • 最后在此Seesion中关闭10046事件
#激活10046事件两种方法
alter session set events '10046 trace name context forever,level 12'
oradebug event 10046 trace name context forever,level 12
#关闭10046事件两种方法
alter session set events '10046 trace name conetxt off'
oradebug event 10046 trace name context off
#tkprof分析跟踪文件
tkprof trc文件 目标文件 sys=no sort=prsela,exeela,fchela (格式化命令)

不过我习惯用oradebug跟10046来做结合,下面简单演示下:

tkprof分析

优点:

a. 可以看出SQL语句对应的等待事件

b. 如果SQL语句中有函数调用,SQL中有SQL,将会都被列出,无处遁形。

c. 可以方便的看出处理的行数,产生的物理逻辑读。

d. 可以方便的看出解析时间和执行时间。

e. 可以跟踪整个程序包

缺陷:

a. 步骤繁琐,比较麻烦

b. 无法判断表被访问了多少次。

c. 执行计划中的谓词部分不能清晰的展现出来。


6. awrsqlrpt.sql

步骤:@?/rdbms/admin/awrsqrpt.sql

选择你要的断点(begin snap 和end snap)

输入sql_id

这样就可以得出结果了。


如果某SQL执行非常长时间才会出结果,甚至慢到返回不了结果,这时候看执行计划就只能用方法1;其实跟踪某条SQL最简单的方法是方法1,其次就是方法2;

如果想观察到某条SQL有多条执行计划的情况,只能用方法4和方法6;

如果SQL中含有多函数,函数中套有SQL等多层递归调用,想准确分析,只能使用方法5;

要想确保看到真实的执行计划,不能用方法1和方法2;

要想获取表被访问的次数,只能使用方法3;

后面会分享更多关于DBA方面内容,感兴趣的朋友可以关注下!

相关推荐

linux安装FTP

1、在nkftp目录下安装ftp,进入到nkftp里面[root@localhostbin]#cd/data/nkftp执行安装命令:[root@localhostnkftp]#rpm-i...

LINUX下搭建FTP服务器

FTP服务器介绍FTP是FileTransferProtocol(文件传输协议)的英文简称,而中文简称为“文传协议”。用于Internet上的控制文件的双向传输。同时,它也是一个应用程序(App...

Linux下如何进行FTP设置

目录:一、Redhat/CentOS安装vsftp软件二、Ubuntu/Debian安装vsftp软件一、Redhat/CentOS安装vsftp软件1.更新yum源yumupdate-y2.安...

推荐使用集串口 SSH远程登录和FTP传输三合一工具MobaXterm

来源:百问网作者:韦东山本文字数:1216,阅读时长:4分钟在以前的资料里,串口和SSH远程登使用SecureCRT,window与ubuntu数据传输使用filezilla,窗口切换来切换去,麻烦也...

如何搭建FTP服务器(Linux系统)

上次说了Windows操作系统下搭建的FTP服务器,那有朋友问我,说买的XX轻量应用服务器都是属于Linux的操作系统,我该如何为搭建FTP服务器呢?...

Linux 命令 ncftp(文件传输)——想玩转linux就请一直看下去

我是IT悟道,点击右上方“关注”,每天分享IT、科技、数码方面的干货。Linuxncftp命令...

如何用 ftp 实现一键上传

简介ftp是Internet标准文件传输协议的用户界面,它允许用户与远程网络站点之间传输文件...

Linux安装ftp

1安装vsftpd组件安装完后,有/etc/vsftpd/vsftpd.conf文件,是vsftp的配置文件。[root@bogon~]#yum-yinstallvsftpd2添加一个...

一天一点点:linux - ftp命令

linuxftp命令设置文件系统相关功能。FTP是ARPANet的标准文件传输协议,该网络就是现今Internet的前身。语法ftp[-dignv][主机名称或IP地址]参数:-d详细显示指令执...

Centos 7 搭建FTP

目录安装软件以及启动服务添加防火墙规则关闭selinuxftp配置常用常用参数详解特殊参数配置文件没有的参数也可以添加到配置中1.安装软件以及启动服务yuminstall-yvsftpdsys...

【Linux】Linux中ftp命令,没有你想的那么简单

本文介绍了Linux中FTP命令的基本用法,包括连接与登录远程服务器,以及解析了FTP协议中五个最常用的操作命令的使用和解析过程。同时,提供了一个包含常用FTP操作命令的表格,供读者参考。通过熟练掌握...

linux 命令行操作ftp

以下是linuxftp命令参数的详解。FTP>!从ftp子系统退出到外壳?FTP>?显示ftp命令说明??和help相同?格式:?[command]说明:[com...

多学习才能多赚钱之:linux如何使用ftp

linux如何使用ftp步骤1:建立FTP连接想要连接FTP服务器,在命令上中先输入ftp然后空格跟上FTP服务器的域名'domain.com'或者IP地址例如:ftpdom...

linux常用网络操作方法:ftp命令使用方法

常用网络操作方法Linux提供了一组强有力的网络命令来为用户服务,这些工具能够帮助用户登录到远程计算机上、传输文件和执行远程命令等。本节介绍下列几个常用的有关网络操作的命令:ftp传输文件tel...

Linux 5.15有望合并Memory Folios方案 内核构建速度可提升7%

甲骨文公司的长期内核开发人员MatthewWilcox已经研究了“内存对开区”概念相当长的一段时间,这可以改善Linux的内存管理,使其具有更大的效率。例如,使用内存对开的基准测试表明,内核的构建速...

取消回复欢迎 发表评论: