查看执行计划的方式有三种:
EXPLAIN PLAN 、V$SQL_PLAN 、SQL*PLUS AUTOTRACE

1.EXPLAIN PLAN:
显示执行相应语句时可以使用的理论计划
读取执行计划:按缩进量读取,缩进越多,越先执行;缩进量相同,先上后下。
dbms_xplan 程序包里三种表函数
display (理论并未真正执行)
display_awr(真正执行)
display_cursor(查询内存中执行过的执行计划)

语法:

EXPLAIN PLAN
SET STATEMENT_ID = ' ' FOR
要查看的SQL语句

输出:

SELECT PLAN_TABLE_OUTPUT FROM TABLE(DBMS_XPLAN.DISPLAY());

display函数中的参数:

  • table_name:指定计划表的名字,缺省值为‘PLAN_TABLE’。
  • statement_id:SQL语句的ID号,是在生成执行计划时使用set statement_id
    命令设置的值,默认值为NULL,当使用默认值时,将显示最近插入计划表中的执行计划。
  • format:用于控制display函数输出内容,其常用值有:
    basic: 仅仅显示最少的信息。基本上包括操作和操作的对象
    typical:显示大部分信息。基本上包括除了别名,提纲和字段投 影外的所有信息,此为缺省值。
    serial: 类似于typical,但不显示并行操作
    all: 显示除提纲之外的所有信息
    advanced:显示所有信息

    相匹配的额外修饰符有:(需要某个修饰符使用“+”,不需要使用“-”,连接之间要有空格)

  • alias:控制包含查询块与别名的显示部分
  • bytes:控制执行计划表中字段bytes的显示
  • cost:控制执行计划表中字段cost的显示
  • note:控制包含注释信息的显示部分
  • outline:控制包含提纲信息的显示部分
  • parallel:控制包含并行处理信息的提示
  • paration:控制并行处理信息的显示,尤其是执行计划表中字段TQ、IN-OUT、PQ Distrib的显示
  • predicate:控制包含谓词filter和access显示部分
  • peeked_binds:控制包含绑定变量窥探部分的显示。仅当生成执行计划时使用了绑定变量是可见
  • projection:控制包含投影信息的显示部分
  • remote:控制远程执行的SQL语句的显示
  • rows: 控制执行计划表中字段rows的显示

例如:

EXPLAIN PLAN
SET STATEMENT_ID = '192' FOR
SELECT * FROM SCOTT.EMP; SELECT PLAN_TABLE_OUTPUT FROM TABLE(DBMS_XPLAN.DISPLAY()); Plan hash value: 3956160932 --------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 14 | 1218 | 3 (0)| 00:00:01 |
| 1 | TABLE ACCESS FULL| EMP | 14 | 1218 | 3 (0)| 00:00:01 |
-------------------------------------------------------------------------- Note
-----
- dynamic sampling used for this statement (level=2)

2.v$sql_plan视图:

视图中包含一种方法,可以查询最近使用过的真正执行过的执行过的执行计划(VSQLPLANSTATISTICS提供了实际的执行统计信息,通过VSQL_PLAN_STATISTICS_ALL,可并列比较优化程序评估结果。)
语法:

SELECT PLAN_TABLE_OUTPUT FROM
TABLE(DBMS_XPLAN.DISPLAY_CURSOR('cfzo0...'));

v$sql_plan查询结果中各列说明(部分):

  • HASH_BALUE:库高速缓存中父语句的散列值
  • ADDRESS:此游标的父游标的句柄地址
  • CHILD_NUMBER:使用此执行计划的子游标编号
  • POSITION:具有相同的PARENT_ID的操作的处理顺序
  • PARENT_ID:操作当前步骤的输出的下一执行步骤的ID
  • ID:执行计划中每个步骤所分配的编号

例如:

---在sys用户下执行了SQL语句:
SELECT * FROM SCOTT.EMP;
---通过SQL文本,在v$sql视图中查询SQL_ID:
select sql_text,sql_id from v$sql where sql_text like'%SCOTT.EMP%';
---得到SQL_ID:
SELECT * FROM SCOTT.EMP 4ay6mhcbhvbf2
---查看执行计划:
SELECT PLAN_TABLE_OUTPUT FROM
TABLE(DBMS_XPLAN.DISPLAY_CURSOR('4ay6mhcbhvbf2')); SELECT * FROM SCOTT.EMP Plan hash value: 3956160932 --------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | | | 3 (100)| |
| 1 | TABLE ACCESS FULL| EMP | 14 | 1218 | 3 (0)| 00:00:01 |
-------------------------------------------------------------------------- Note
-----
- dynamic sampling used for this statement (level=2)

3.sqlplus autotrace:
—输入set autot命令可查看语法:
SQL> set autot
Usage: SET AUTOT[RACE] {OFF | ON | TRACE[ONLY]} [EXP[LAIN]] [STAT[ISTICS]]
—说明
SET AUTOTRACE OFF 此为默认值,即关闭Autotrace
SET AUTOTRACE ON 同时输出执行结果以及统计信息和执行计划信息。
SET AUTOTRACE ON EXPLAIN 只打开执行计划报表,显示命令结果,不显示统计信息。
SET AUTOTRACE ON STATISTICS 只打开统计信息报表,显示命令结果,不显示执行计划。
SET AUTOTRACE TRACEONLY 不显示命令的执行结果,显示执行计划和统计信息。
SET AUTOTRACE TRACEONLY EXPLAIN 只显示执行计划信息。
SET AUTOTRACE TRACEONLY STATISTICS 只显示统计信息。

【Oracle】三种方式查看SQL语句的执行计划的更多相关文章

  1. oracle中查看sql语句的执行计划

    1.在pl/sql中打开cmd命令容器 2.在cmd命令窗口中输入:explain plan for select * from t; 3.查看sql语句的执行计划:select * from tab ...

  2. 配置数据源的三种方式和sql心跳的配置

    三种方式配置数据源连接池: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=" ...

  3. Hibernate 三种状态变化 与 sql 语句的关系

    前言:在Hibernate中有三种状态,对它的深入理解,才能更好的理解hibernate的运行机理,刚开始不太注意这些概念,后来发现它是重要的.对于理解hibernate,JVM和sql的关系有更好的 ...

  4. day57-mysql-五种约束和sql语句逻辑执行顺序

    二.sql语句逻辑执行顺序 () SELECT () DISTINCT <select_list> 去重复 () FROM <left_table> () <join_t ...

  5. 如何通过outline为SQL语句指定执行计划

    创建测试表 以用户jyu连接,创建测试表 SQL> conn jyu/jyu; Connected. SQL> create table t (id number, name varcha ...

  6. SQL语句的执行计划(oracle表的三种链接方式)

    SQL语句我们写完之后,就是分析其优化,这就要求我们了解到底数据是怎么存储. 首先我们需要了解,表链接的几种方式 nested loop join sort merge join hash join ...

  7. 查看sql 语句io执行情况

    set statistics io,time on 表 'xx'.扫描计数 1,逻辑读取 19 次,物理读取 0 次,预读 0 次,lob 逻辑读取 76 次,lob 物理读取 0 次,lob 预读 ...

  8. MySQL通过Explain查看select语句的执行计划结果触发写操作

    [背景] 某某同学执行了一下Explain结果结果发现数据库有了一条写入操作,恭喜这位同学你的锅到货了,你签收一下: 对! 你没有听错,在一种场景下就算是Explain也会引发数据的写操作,就这是外层 ...

  9. 【测试】使用hr用户下的employees表写一条SQL语句,执行计划走索引全扫描

    SQL> select count(*) from employees; COUNT(*) ---------- Execution Plan ------------------------- ...

随机推荐

  1. Webpack 快速上手(下)

    杏仁前端开发工程师,代码洁癖症早期,关注前端技术. 由于文章篇幅较长,为了更好的阅读体验,本文分为上.中.下三篇: 上篇介绍了什么是 webpack,为什么需要 webpack,webpack 的文件 ...

  2. lvs负载均衡net模式

    环境配置,一台双网卡的ens33,ens37,ens37的网关是ens33的IP,指定一下nginx ens33,192.168.30.22,ens37,172.16.1.1nginx  192.16 ...

  3. Centos7从3.10升级内核到4.9后无法启动解决办法:mpt[23]sas驱动问题

    Centos7升级内核后无法启动解决办法:mpt[23]sas驱动问题 前言 这个问题存在有一段时间了,之前做的centos7的ISO,在进行内核的升级以后就存在这个问题: 系统盘在板载sata口上是 ...

  4. 洛谷P1316 丢瓶盖【二分+递推】

    陶陶是个贪玩的孩子,他在地上丢了A个瓶盖,为了简化问题,我们可以当作这A个瓶盖丢在一条直线上,现在他想从这些瓶盖里找出B个,使得距离最近的2个距离最大,他想知道,最大可以到多少呢? 输入输出格式 输入 ...

  5. Noip 2013 练习

    转圈游戏 传送门 Solution 快速幂 Code //By Menteur_Hxy #include <cstdio> #include <cstdlib> #includ ...

  6. Git 基础教程 之 版本回退

    不断对文件进行修改,然后不断提交修改到版本库里. 当你觉得文件修改到一定程度时,可以保存一个“快照”,这个“快照”在Git中称为“commit”. 一旦文件被改乱了.误删了,都可以从最近一个“comm ...

  7. flask日期和时间

    本文翻译自The Flask Mega-Tutorial Part XII: Dates and Times 这是Flask Mega-Tutorial系列的第十二部分,我将告诉你如何以适配所有用户的 ...

  8. Ubuntu下ss的安装与使用

    不得不说,linux真的有种让人用上就爱上的魔力,正好最近Ubuntu出了16.04,便索性装了个win10+Ubuntu的双系统,也算是告慰那永远留在老硬盘里的虚拟机吧. 言归正传,换上Ubuntu ...

  9. asp.net--ado.net5大对象代码示例

    连接数据库 string conn_string ="Data Source=localhost;Initial Catalog=SQLtest;Integrated Security=Tr ...

  10. 洛谷——P1910 L国的战斗之间谍

    https://www.luogu.org/problem/show?pid=1910#sub 题目背景 L国即将与I国发动战争!! 题目描述 俗话说的好:“知己知彼,百战不殆”.L国的指挥官想派出间 ...