1.用explain plan for来获取执行计划

  1. explain plan for <sql>;
  2.  
  3. select * from table(dbms_xplan.display());

结果如下:

---------------------------------------------------------------------------------------------------------------------

优点

  1. 不需要真实执行sql,方便快捷

缺点

  1. 这里的执行计划并不是真实的执行计划
  2. 不能获取运行时的相关统计信息(产生多少逻辑读,多少次递归调用,多少次物理读的情况)
  3. 无法判断表被访问了多少次
  4. 无法判断处理了多少行数据

---------------------------------------------------------------------------------------------------------------------

2.用autotrace 来获取执行计划

  1. SET AUTOTRACE OFF --此为默认值,即关闭Autotrace
  2.  
  3. SET AUTOTRACE ON EXPLAIN --只显示执行计划和执行结果
  4.  
  5. SET AUTOTRACE ON STATISTICS --只显示执行的统计信息和执行结果
  6.  
  7. SET AUTOTRACE ON --包含执行计划,统计信息和执行结果
  8.  
  9. SET AUTOTRACE TRACEONLY --只显示执行计划
  1. 使用 SET AUTOTRACE ON EXPLAIN 时,显示执行结果,和执行计划,如图:

  1. 使用 SET AUTOTRACE ON STATISTICS 时,显示执行结果,和统计信息,如图:

  1. 使用 SET AUTOTRACE ON 时,显示执行结果,执行计划和统计信息,如图:

  1. 使用 SET AUTOTRACE TRACEONLY 时,显示执行计划和统计信息如图:

---------------------------------------------------------------------------------------------------------------------
优点

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

缺点

  1. 获取的不是真实的执行计划
  2. 无法看到表被访问了多少次。

---------------------------------------------------------------------------------------------------------------------
3.使用 gather_plan_statistics 获取高级执行计划

  1. --方法1
  2. alter session set statistics_level=all ;
  3.  
  4. sql;
  5.  
  6. select * from table(dbms_xplan.display_cursor(null,null,'allstats last'));
  7.  
  8. --方法2
  9. sql;(sql中加 HINT (gather_plan_statistics))
  10.  
  11. select * from table(dbms_xplan.display_cursor(null,null,'allstats last'));

如图:

---------------------------------------------------------------------------------------------------------------------

优点

  1. 真实的执行计划
  2. 能看到表被扫描的次数
  3. 能看到oracle预测行数和真实返回的行数
  4. 可以看到逻辑读数

缺点

  1. 必须等sql真实执行过才能看到执行计划
  2. 没有统计信息

---------------------------------------------------------------------------------------------------------------------

4.使用10046事件来获取执行计划

  1. alter session set events '10046 trace name context forever,level 12';
  2.  
  3. SELECT * FROM t1, t2 WHERE t1.id = t2.t1_id AND t1.n IN (18, 19);
  4.  
  5. alter session set events '10046 trace name context off';
  6.  
  7. select d.value
  8. || '/'
  9. || LOWER (RTRIM(i.INSTANCE, CHR(0)))
  10. || '_ora_'
  11. || p.spid
  12. || '.trc' trace_file_name
  13. from (select p.spid
  14. from v$mystat m,v$session s, v$process p
  15. where m.statistic#=1 and s.sid=m.sid and p.addr=s.paddr) p,
  16. (select t.INSTANCE
  17. FROM v$thread t,v$parameter v
  18. WHERE v.name='thread'
  19. AND(v.VALUE=0 OR t.thread#=to_number(v.value))) i,
  20. (select value
  21. from v$parameter
  22. where name='user_dump_dest') d;
  23.  
  24. exit
  25.  
  26. tkprof trc文件路径 格式化后路径 格式化参数

oracle 执行计划的获取方法的更多相关文章

  1. 查看Oracle执行计划的几种方法

    查看Oracle执行计划的几种方法 一.通过PL/SQL Dev工具 1.直接File->New->Explain Plan Window,在窗口中执行sql可以查看计划结果.其中,Cos ...

  2. 看懂Oracle执行计划

    最近一直在跟Oracle打交道,从最初的一脸懵逼到现在的略有所知,也来总结一下自己最近所学,不定时更新ing- 一:什么是Oracle执行计划? 执行计划是一条查询语句在Oracle中的执行过程或访问 ...

  3. 转:Oracle 执行计划(Explain Plan) 说明

    Oracle 执行计划(Explain Plan) 说明 原贴地址:http://blog.csdn.net/tianlesoftware/article/details/5827245   如果要分 ...

  4. [转]看懂Oracle执行计划

    原文地址:https://www.cnblogs.com/Dreamer-1/p/6076440.html 一:什么是Oracle执行计划? 执行计划是一条查询语句在Oracle中的执行过程或访问路径 ...

  5. 看懂Oracle执行计划、表连接方式

    看懂Oracle执行计划  原文:https://www.cnblogs.com/Dreamer-1/p/6076440.html 最近一直在跟Oracle打交道,从最初的一脸懵逼到现在的略有所知,也 ...

  6. 02 看懂Oracle执行计划

    看懂Oracle执行计划   最近一直在跟Oracle打交道,从最初的一脸懵逼到现在的略有所知,也来总结一下自己最近所学,不定时更新ing… 一:什么是Oracle执行计划? 执行计划是一条查询语句在 ...

  7. oracle执行计划(转载)

    转载自 https://www.cnblogs.com/Dreamer-1/p/6076440.html 一:什么是Oracle执行计划? 执行计划是一条查询语句在Oracle中的执行过程或访问路径的 ...

  8. Oracle调优之看懂Oracle执行计划

    @ 目录 1.文章写作前言简介 2.什么是执行计划? 3.怎么查看执行计划? 4.查看真实执行计划 5.看懂Oracle执行计划 5.1 查看explain 5.2 explain执行顺序 5.3 访 ...

  9. (Oracle)看懂Oracle执行计划(转载)

    最近一直在跟Oracle打交道,从最初的一脸懵逼到现在的略有所知,也来总结一下自己最近所学,不定时更新ing- 一:什么是Oracle执行计划? 执行计划是一条查询语句在Oracle中的执行过程或访问 ...

随机推荐

  1. GO 字符串反转

    字符串反转 即 abc 反转后成 cba 思路:两边都设置一个游标,然后互换位置,游标同步向中间移动,再互换. for i, j := 0, len(s)-1; i < j; i, j = i+ ...

  2. Redis 客户端重试指南

    本作品采用知识共享署名-非商业性使用 4.0 国际许可协议进行许可. 在互联网服务中,特别是在云环境下,网络及硬件环境复杂,所有应用程序都可能遇到暂时性故障.暂时性故障包括瞬时的网络抖动,服务暂时不可 ...

  3. (三)MySQL数据管理

    3.1 外键(了解即可) 方式一:在创建表的时候,增加约束(麻烦,比较复杂) CREATE TABLE IF NOT EXISTS `student`( `id` INT(4) NOT NULL AU ...

  4. Part 15 AngularJS ng init directive

    The ng-init directive allows you to evaluate an expression in the current scope.  In the following e ...

  5. 9组-Alpha冲刺-3/6

    一.基本情况 队名:不行就摆了吧 组长博客:https://www.cnblogs.com/Microsoft-hc/p/15546622.html 小组人数: 8 二.冲刺概况汇报 卢浩玮 过去两天 ...

  6. 【Mysql】表锁 行锁 记录锁 间隙锁

    Mysql中的锁 基于锁的属性分类:共享锁.排他锁. 基于锁的状态分类:意向共享锁.意向排它锁 根据锁的粒度分类:全局锁.页锁.表级锁.行锁(记录锁.间隙锁.和临键锁),实际上的锁就这些,上面两种分类 ...

  7. 菜鸡的Java笔记 第十三 String 类的两种实例化方法

    String 类的两种实例化方法 String 类的两种实例化方式的区别 String 类对象的比较 Stirng 类对象的使用分析 /*    1.String 类的两种实例化方式的区别       ...

  8. OpenCV常用操作函数大全

    https://blog.csdn.net/Vici__/article/details/100714822 目录 cv2常用类: 1.图片加载.显示和保存 2.图像显示窗口创建与销毁 3.图片的常用 ...

  9. Android学习—下载Android SDK的两种方式

    在Android Studio中下载Android SDK的两种方式 Android studio下载地址:http://www.android-studio.org/ 方式一.设置HTTP Prox ...

  10. [loj2506]tree

    2018年论文题,以下是论文前3章主要内容,与原题解相关部分为第4章中的启发式合并,也可快速跳至原题解 1.复杂度分析 Treap 定理1:$n$个节点的Treap的期望深度为$o(\log n)$ ...