ORACLE SQL性能优化系列 (七)
来源:互联网 发布:js url中文传参乱码 编辑:程序博客网 时间:2024/06/07 09:46
转自:http://www.cnblogs.com/HondaHsu/archive/2008/12/02/1345391.html
24. 用EXPLAIN PLAN分析SQL语句
EXPLAIN PLAN 是一个很好的分析SQL语句的工具,它甚至可以在不执行SQL的情况下分析语句.通过分析,我们就可以知道ORACLE是怎么样连接表,使用什么方式扫描表(索引扫描或全表扫描)以及使用到的索引名称.
你需要按照从里到外,从上到下的次序解读分析的结果. EXPLAIN PLAN分析的结果是用缩进的格式排列的,最内部的操作将被最先解读,如果两个操作处于同一层中,带有最小操作号的将被首先执行.
NESTED LOOP是少数不按照上述规则处理的操作,正确的执行路径是检查对NESTED LOOP提供数据的操作,其中操作号最小的将被最先处理.
译者按:
通过实践,感到还是用SQLPLUS中的SET TRACE功能比较方便.
举例:
SQL> list
1 SELECT *
2 FROM dept, emp
3* WHERE emp.deptno = dept.deptno
SQL> set autotrace traceonly /*traceonly可以不显示执行结果*/
SQL> /
14 rows selected.
Execution Plan
----------------------------------------------------------
0 SELECT STATEMENT Optimizer=CHOOSE
1 0 NESTED LOOPS
2 1 TABLE ACCESS (FULL) OF 'EMP'
3 1 TABLE ACCESS (BY INDEX ROWID) OF 'DEPT'
4 3 INDEX (UNIQUE SCAN) OF 'PK_DEPT' (UNIQUE)
Statistics
----------------------------------------------------------
0 recursive calls
2 db block gets
30 consistent gets
0 physical reads
0 redo size
2598 bytes sent via SQL*Net to client
503 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
14 rows processed
通过以上分析,可以得出实际的执行步骤是:
1. TABLE ACCESS (FULL) OF 'EMP'
2. INDEX (UNIQUE SCAN) OF 'PK_DEPT' (UNIQUE)
3. TABLE ACCESS (BY INDEX ROWID) OF 'DEPT'
4. NESTED LOOPS (JOINING 1 AND 3)
- ORACLE SQL性能优化系列 (七)
- ORACLE SQL性能优化系列 (七 )
- ORACLE SQL性能优化系列 (七) (八)
- ORACLE SQL性能优化系列(七)
- ORACLE SQL性能优化系列 (七)
- ORACLE SQL性能优化系列(七)
- ORACLE SQL性能优化系列 (七 )
- ORACLE SQL性能优化系列 (七)
- ORACLE SQL性能优化系列 (七)
- ORACLE SQL性能优化系列(七)
- ORACLE SQL性能优化系列 (七)
- ORACLE SQL性能优化系列 (七)
- ORACLE SQL性能优化系列 (七 )
- ORACLE SQL性能优化系列 (七)
- ORACLE SQL性能优化系列
- ORACLE SQL性能优化系列
- ORACLE SQL性能优化系列
- ORACLE SQL性能优化系列
- 基于注释的Spring cache 缓存介绍
- STL的底层实现和优缺点
- Repo command summary
- 小猫统计开发动态:表关联设计,目前拖动表,连线不能随之移动
- 使用事务操作SQLite数据库
- ORACLE SQL性能优化系列 (七)
- linux网络编程之TCP/IP基础:TCP连接的建立和断开、滑动窗口
- Alfred使用手册1-初识篇
- iOS9之后去AppStore给我们评价AppStore显示无法连接到AppStore
- 欢迎使用CSDN-markdown编辑器
- ListView的几种形式
- ORACLE SQL性能优化系列 (六)
- Word2010如何从正文开始设置页眉页码?
- Python字符串