oracle执行计划解释

简介:

设置执行计划方法:

set autotrace off          默认值,关闭执行计划

set autotrace on explain     只显示执行计划

set autotrace on statistics   只显示执行计划统计信息

set autotrace on          显示执行计划和统计信息

set autotrace traceonly      与on相似,不显示语句的执行结果


1.oracle数据库访问数据的方法

(1).全表扫描(Full Table Scans,FTS)

(2).通过隐藏rowid字段扫描(Table Access by ROWID)

(3).索引范围扫描(Index range Scan)

(4).索引唯一扫描(Index unique scan)

(5).索引全扫描(Index full scan)

(6).索引快速扫描(Index fast full scan)


1).全表扫描

SQL> set autotrace on

SQL> select * from emp where comm=1400;

EMPNO ENAME    JOB   MGR HIREDATE    SAL     COMM    DEPTNO

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

7654 MARTIN   SALESMAN  7698 28-SEP-81   1250   1400     30


Execution Plan

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

Plan hash value: 3956160932

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

| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |

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

|   0 | SELECT STATEMENT  |      |     1 |    38 |     3   (0)| 00:00:01 |

|*  1 |  TABLE ACCESS FULL| EMP  |     1 |    38 |     3   (0)| 00:00:01 |

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


Predicate Information (identified by operation id):

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

   1 - filter("COMM"=1400)

Access:表示条件的值将会影响数据的访问路径(表和索引)

Filter:表示条件的值不会影响数据的访问路径,只起过滤作用

Statistics

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

          1  recursive calls

          0  db block gets        --读了多少个数据块

          7  consistent gets      --逻辑读(从buffer cache中读取的block数量)

          0  physical reads       --物理读(从磁盘中读取的block数量)

          0  redo size          --产生多少redo日志

       1028  bytes sent via SQL*Net to client   --客户端传入的字节数

        523  bytes received via SQL*Net from client  --服务端传入到客户端的字节数

          2  SQL*Net roundtrips to/from client

          0  sorts (memory)       --排序占用的内存

          0  sorts (disk)        --排序占用的磁盘

          1  rows processed       --影响多少行

SQL>


2).rowid字段扫描

SQL> select * from emp where rowid='AAAVREAAEAAAACXAAN';

EMPNO ENAME     JOB        MGR HIREDATE       SAL       COMM     DEPTNO

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

7934 MILLER     CLERK       7782 23-JAN-82     1300              10

Execution Plan

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

Plan hash value: 1116584662

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

| Id  | Operation                  | Name | Rows  | Bytes | Cost (%CPU)| Time     |

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

|   0 | SELECT STATEMENT           |      |     1 |    38 |     1   (0)| 00:00:01 |

|   1 |  TABLE ACCESS BY USER ROWID| EMP  |     1 |    38 |     1   (0)| 00:00:01 |

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

Statistics

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

          1  recursive calls

          0  db block gets

          1  consistent gets

          0  physical reads

          0  redo size

       1022  bytes sent via SQL*Net to client

        523  bytes received via SQL*Net from client

          2  SQL*Net roundtrips to/from client

          0  sorts (memory)

          0  sorts (disk)

          1  rows processed

SQL>


3).索引范围扫描

SQL> create index in_sal on emp(sal);

Index created.

SQL> select * from emp where sal < 1000;

 EMPNO ENAME    JOB       MGR HIREDATE        SAL       COMM     DEPTNO

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

 7369 SMITH    CLERK     7902 17-DEC-80        800               20

 7900 JAMES    CLERK     7698 03-DEC-81        950               30

Execution Plan

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

Plan hash value: 3065173639

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

| Id  | Operation                   | Name   | Rows  | Bytes | Cost (%CPU)| Time     |

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

|   0 | SELECT STATEMENT            |        |     1 |    38 |     2   (0)| 00:00:01 |

|   1 |  TABLE ACCESS BY INDEX ROWID| EMP    |     1 |    38 |     2   (0)| 00:00:01 |

|*  2 |   INDEX RANGE SCAN          | IN_SAL |     1 |       |     1   (0)| 00:00:01 |

--------------------------------------------------------------------------------------Predicate Information (identified by operation id):

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

   2 - access("SAL"<1000)

Statistics

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

          1  recursive calls

          0  db block gets

          4  consistent gets

          0  physical reads

          0  redo size

       1115  bytes sent via SQL*Net to client

        523  bytes received via SQL*Net from client

          2  SQL*Net roundtrips to/from client

          0  sorts (memory)

          0  sorts (disk)

          2  rows processed

SQL>


(4).索引唯一扫描

SQL> select * from emp where empno=7566;

EMPNO ENAME      JOB        MGR HIREDATE       SAL       COMM     DEPTNO

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

7566 JONES      MANAGER      7839 02-APR-81     2975               20


Execution Plan

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

Plan hash value: 2949544139

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

| Id  | Operation                   | Name   | Rows  | Bytes | Cost (%CPU)| Time     |

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

|   0 | SELECT STATEMENT            |        |     1 |    38 |     1   (0)| 00:00:01 |

|   1 |  TABLE ACCESS BY INDEX ROWID| EMP    |     1 |    38 |     1   (0)| 00:00:01 |

|*  2 |   INDEX UNIQUE SCAN         | PK_EMP |     1 |       |     0   (0)| 00:00:01 |

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

Predicate Information (identified by operation id):

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

   2 - access("EMPNO"=7566)

Statistics

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

          1  recursive calls

          0  db block gets

          2  consistent gets

          0  physical reads

          0  redo size

        892  bytes sent via SQL*Net to client

        512  bytes received via SQL*Net from client

          1  SQL*Net roundtrips to/from client

          0  sorts (memory)

          0  sorts (disk)

          1  rows processed

SQL>


(5).索引全扫描

SQL> select * from emp where sal >2000 order by empno;        

EMPNO ENAME      JOB          MGR HIREDATE       SAL      COMM     DEPTNO

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

7566 JONES      MANAGER         7839 02-APR-81    2975              20

7698 BLAKE      MANAGER         7839 01-MAY-81    2850              30

7782 CLARK      MANAGER         7839 09-JUN-81    2450              10

7788 SCOTT      ANALYST         7566 19-APR-87    3000              20

7839 KING       PRESIDENT           17-NOV-81    5000              10

7902 FORD       ANALYST         7566 03-DEC-81    3000              20


6 rows selected.

Execution Plan

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

Plan hash value: 4170700152

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

| Id  | Operation                   | Name   | Rows  | Bytes | Cost (%CPU)| Time     |

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

|   0 | SELECT STATEMENT            |        |    10 |   380 |     2   (0)| 00:00:01 |

|*  1 |  TABLE ACCESS BY INDEX ROWID| EMP    |    10 |   380 |     2   (0)| 00:00:01 |

|   2 |   INDEX FULL SCAN           | PK_EMP |    14 |       |     1   (0)| 00:00:01 |

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

Predicate Information (identified by operation id):

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

   1 - filter("SAL">2000)

Statistics

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

          1  recursive calls

          0  db block gets

          4  consistent gets

          0  physical reads

          0  redo size

       1263  bytes sent via SQL*Net to client

        523  bytes received via SQL*Net from client

          2  SQL*Net roundtrips to/from client

          0  sorts (memory)

          0  sorts (disk)

          6  rows processed

SQL> 


6)索引快速扫描


2.使用explain plan for查看执行计划

SQL> explain plan for select * from emp where sal > 3000;

Explained.

SQL> seletc * from table(dbms_xplan.display);

PLAN_TABLE_OUTPUT

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

Plan hash value: 3065173639

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

| Id  | Operation                   | Name   | Rows  | Bytes | Cost (%CPU)| Time     |

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

|   0 | SELECT STATEMENT            |        |     7 |   266 |     2   (0)| 00:00:01 |

|   1 |  TABLE ACCESS BY INDEX ROWID| EMP    |     7 |   266 |     2   (0)| 00:00:01 |

|*  2 |   INDEX RANGE SCAN          | IN_SAL |     7 |       |     1   (0)| 00:00:01 |

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

Predicate Information (identified by operation id):


PLAN_TABLE_OUTPUT

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

   2 - access("SAL">3000)

14 rows selected.

SQL>










本文转自 z597011036 51CTO博客,原文链接:http://blog.51cto.com/tongcheng/1860137,如需转载请自行联系原作者
目录
相关文章
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
323 1
|
监控 Oracle 关系型数据库
Oracle 12c的Adaptive执行计划:数据的“聪明导航员”
【4月更文挑战第19天】Oracle 12c的Adaptive执行计划是数据库查询的智能优化工具,能根据实际运行情况动态调整执行策略。它像一个聪明的导航系统,不仅生成初始执行计划,还能实时监控并适应统计信息和资源变化,例如自动切换索引或调整并行度。此外,它支持自适应连接和统计信息收集,提升处理复杂查询和变化数据环境的能力。数据管理员应充分利用这一特性来优化查询性能和用户体验。
|
SQL Oracle 关系型数据库
Oracle 性能优化技巧-获取真实执行计划
Oracle 性能优化技巧-获取真实执行计划
389 0
Oracle 性能优化技巧-获取真实执行计划
|
SQL 缓存 监控
Oracle中如何生成有用的SQL 执行计划(译)
漫画戴夫·艾伦(Dave Allen)曾经讲过一个古老的笑话,一个旅行者问路人去某个城镇的路,路人只是说:“如果我是你,我就不会从这里开始。”
255 0
|
SQL 存储 缓存
获取和解读Oracle中SQL的执行计划(译文)
生成和显示 SQL 语句的执行计划是大多数 DBA、SQL 开发人员和性能专家的常见任务,因为它提供了 SQL 语句执行性能相关的信息。执行计划显示执行 SQL 语句的详细步骤,这些步骤表示为一组使用和生成行的数据库运算符。运算符的顺序和实现由查询优化器根据查询转换和物理优化技术来决定。
494 0
|
SQL Oracle 关系型数据库
Oracle优化05-执行计划
Oracle优化05-执行计划
608 0
|
SQL 存储 Oracle
Oracle数据库 | SQL语句执行计划、语句跟踪与优化实例
Oracle数据库 | SQL语句执行计划、语句跟踪与优化实例
490 0
|
SQL Oracle 关系型数据库

热门文章

最新文章

推荐镜像

更多