Oracle SQL性能优化深入浅出 3

用EXPLAIN PLAN 分析SQL语句:
EXPLAIN PLAN 是一个很好的分析SQL语句的工具,它甚至可以在不执行SQL的情况下分析语句. 通过分析,我们就可以知道ORACLE是怎么样连接表,使用什么方式扫描表(索引扫描或全表扫描)以及使用到的索引名称.
你需要按照从里到外,从上到下的次序解读分析的结果.
EXPLAIN PLAN分析的结果是用缩进的格式排列的, 最内部的操作将被最先解读, 如果两个操作处于同一层中,带有最小操作号的将被首先执行.
NESTED LOOP是少数不按照上述规则处理的操作, 正确的执行路径是检查对NESTED LOOP提供数据的操作,其中操作号最小的将被最先处理.

使用TKPROF工具分析SQL语句:
SQL trace 工具收集正在执行的SQL的性能状态数据并记录到一个跟踪文件中. 这个跟踪文件提供了许多有用的信息,例如解析次数.执行次数,CPU使用时间等.这些数据将可以用来优化你的系统.
设置SQL TRACE在会话级别: 有效
ALTER SESSION SET SQL_TRACE TRUE
设置SQL TRACE 在整个数据库有效, 你必须将SQL_TRACE参数在init.ora中设为TRUE, USER_DUMP_DEST参数说明了生成跟踪文件的目录
再使用TKPROF对TRACE文件进行分析分析结果更加准确、清楚

在SQLPLUS 配置AUTOTRACE:
SET AUTOTRACE OFF :不能获得AUTOTRACE报告. 这是默认的.
SET AUTOTRACE ON EXPLAIN :仅仅显示优化器执行计划的AUTOTRACE报告
SET AUTOTRACE ON STATISTICS :仅仅显示SQL语句执行的统计结果的AUTOTRACE报告
SET AUTOTRACE ON :包括上面两项内容的AUTOTRACE报告
SET AUTOTRACE TRACEONLY :与SET AUTOTRACE ON类似,所有的统计和数据都在,但不可以打印

SQL 调整的目标:
1)去掉不必要的大型表的全表扫描。
2)缓存小型表的全表扫描。
3)校验优化索引的使用。
4)检验优化的连接技术。

在设计和开发时调整:
当设计你的系统时,使用下列优化性能的准则:
- 消除客户机/服务器应用中不必要的网络传输,使用存储过程。
- 使用适合你系统的Oracle服务器选件(例如,并行查询或分布式数据库)。
- 除非你的应用有特殊的需要,否则使用缺省的Oracle锁。
- 利用数据库记住应用模块,以便能以每个模块为基础来追踪性能。
- 选择你的数据块的最佳大小。 -- 原则上来说大一些的性能较好。
- 分布你的数据,使得一个节点使用的数据本地存贮在该节点中。


猜你喜欢

转载自maosheng.iteye.com/blog/1922116