Oracle SQL性能优化深入浅出 3

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

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

[b]在SQLPLUS 配置AUTOTRACE:[/b]
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类似,所有的统计和数据都在,但不可以打印

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

[b]在设计和开发时调整:[/b]
当设计你的系统时,使用下列优化性能的准则:
- 消除客户机/服务器应用中不必要的网络传输,使用存储过程。
- 使用适合你系统的Oracle服务器选件(例如,并行查询或分布式数据库)。
- 除非你的应用有特殊的需要,否则使用缺省的Oracle锁。
- 利用数据库记住应用模块,以便能以每个模块为基础来追踪性能。
- 选择你的数据块的最佳大小。 -- 原则上来说大一些的性能较好。
- 分布你的数据,使得一个节点使用的数据本地存贮在该节点中。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle SQL性能优化是一个综合性的问题,需要从多个方面进行考虑和优化。以下是一些常见的优化技巧: 1. 建立索引:索引是提高查询效率的重要手段,可以在查询时快速定位到符合条件的数据。建立索引需要根据具体情况选择适当的字段,同时避免过多、重复或不必要的索引。 2. 使用优化器:Oracle数据库内置了优化器,可以自动选择最优的查询路径和执行计划。在编写SQL语句时,可以使用HINT指令来引导优化器选择特定的查询路径。 3. 减少数据传输:减少查询结果的数据量,可以大幅度提升查询效率。可以通过选择合适的字段、使用SELECT子句中的DISTINCT关键字、限制查询结果的行数等方式来实现。 4. 避免全表扫描:全表扫描是一种低效的查询方式,应该尽量避免。可以通过建立索引、优化查询条件、分区表等方式来减少全表扫描的次数。 5. 优化SQL语句:在编写SQL语句时,应注意避免使用子查询、使用OR操作符、使用LIKE操作符等低效的操作。可以通过重构SQL语句、使用存储过程等方式来提高查询效率。 6. 定期维护数据库:定期进行数据库维护操作,如清理无用数据、优化表结构、重建索引等,可以保持数据库的良好状态,提高查询效率。 以上是一些常见的Oracle SQL性能优化技巧,但具体的优化方案需要根据实际情况进行分析和选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值