1、优化前可通过各种手段先观察观察 SOL 涉及的表结构、索引等,看它们有无不合理之处,急于动手改造 SO 太盲目了,是没有抓住主要矛盾的体现。

2、做事要有方法论,要先整体后局部,解决问题要注 重效率,先尽量考虑不改写的优化,再考虑改写的优化 而不改写的优化靠的是 体系结构知识的沉淀,而改写则妥考虑、逻辑等价改写和业务改写两大思路,其中 业务改写是 SQL 优化的最高境界 另外还是妥有一定的知识沉淀,高级 SQL 语法也妥掌握,其在很多场合下能帮上我们大忙。

3、要花一小时时间才定位到某处需要 建立索引,如果建索引有依据的规范并且能快速被体检报告诊断出来。这里涉及了数据库的设计规范。如果性能低下的 SOL 在运行之前能被事先捞取出来, 则很多故障就能避免。这里涉及 SOL 写法的规范。

4、性能工具:AWR、ASH、ADDM、AWRDD

     AWR:关注数据库的整体性能报告;

  ASH:是数据库的等待事件与哪些sql具体对应的报告(生成该报告的命令:@?/rdbms/admin/ashrpt.sql);

  ADDM:oracle给出的建议

  AWRRD:oracle针对不同时段的性能的比对报告。(生成该报告的命令:@?/rdbms/admin/awrddrpt.sql)

  Oracle 提供的一种性能收集和分 析工具,它能提供一个时间段内整个系统资源使用情况的报告 这个报告里有很多总体性指标 来判断系统是否健康。没毛病最好 万一有毛病,问题出在什么模块,是日志切换过于频繁, 还是硬解析过大 还是某些 相关等待事件在耗资源……这就是AWR报告。

  假设你的数据库是 SOL 相关等待事件问题, AWR 报告很可能只告诉你有 这个问题而无法告诉你是哪些 sql发的。你要得到这些指标 想了解具体某些 sql和相关等待事件的对应需要做进一步的信息收集 那就是 ASH报告。

 

 5、AWR需要关注的点:

  DB Time、load_profile、efficiency percentages、top 5 events、SQL Statistics、Segment_statistic。

  DB Time:指的是花费在数据库调用上的总时间,是数据库负载的指示灯。 

  load_profile:性能的总体参数,比如redo size显示每秒的日志尺寸和平均每个事务的日志尺寸。Transactions:每秒事务数。

  efficiency percentages:命中率指标

  ….

6、oracle获取执行计划的方法(只摘录3种)

  1)、explain plan for select id from test01 where id = \’2019-09-20\’;
      select * from table (dbms_xplan.display()); 

    优点:无须真正执行,快捷方便
    缺陷:    没有输出运行时的相关统计信息(产生多少逻辑读,多少次递归调用,多少次物理读的情况) ;
        无法判断处理了多少行;
        无法判断表被访问了多少次。

      

 

 

   2)、set autotrace on;

    优点  1. 可以输出运行时的相关统计信息(产生多少逻辑读,多少次递归调用,多少次物理读的情况),
        2.虽然必须要等语句执行完毕后才可以输出执行计划 但是可以有 traceonly 开关来控制返回结果不打屏输出。
    缺陷  1. 必须要等到语句真正执行完毕后,才可以出结果,
        2. 无法看到表被访问了多少次。

        set autotrace on;
        set linesize 1000;
        set timing on;
        select * from t3 where rownum<10;

      

 

 

   3)、alter session set statistics_level=all ;

    select * from table(dbms_xplan.display_cursor(null,null,\’allstats last\’)) ;

    优点: 可以清晰地从 ST TS 得出表被访问多少次;
           可以清晰地从 E-ROWS A-ROWS 中得到预测的行数和真实的行数 从而可以准确判断 Oracle 评估是否准确;
        虽然没有专门的输出运行时的相关统计信息 但是执行计划中的 BUFFERS 就是真实的逻辑读的数值。
    缺陷 :   必须要等到语句真正执行完毕后,才可以出结果
        无法控制记录打屏输出,不像 autotrace traceonly 可以控制不将结果打屏输出;
        看不出递归调用的次数,看不出物理读的数值(不过逻辑读才是重点儿)

    

7、执行计划:

  Starts 为该 SQL 执行的次数。
  E-Rows 为执行计划预计的行数。
  A-Rows 为实际、返回的行数。 A-Rows和E-Rows 做比较,就可以确定哪一步执行计划出了问题。
  A-Time 为每一步实际执行的时间(HH:MM:SS.FF),根据这一行可以知道该 SQL 耗时在哪个地方。
  Buffers 为每一步实际执行的逻辑读或致性读。
  Reads 为物理读。
  OMem 当前操作完成所有内存工作区 (Work Aera)操作所总共使用私有内存( PGA )中工作区的大小,这个数据是由优化器统计数据以及前一次执行的性能数据估算得出的。
  lMem :当工作区大小无法满足操作所需的大小时 需要将部分数据写人临时磁盘空间中(如果仅需要写入一次就可以完成操作,就称一次通过, One-Pass ;否则为多次通过 ,Multi-Pass )。该列数据为语句最后一次执行中,单次写磁盘所需要的内存大小 这个是由优化器统计数据以及前一次执行的性能数据估算得出的。
  User-Mem 语旬最后一次执行中,当前操作所使用的内存工作区大小 括号里面为(发生磁盘交换的次数 次即为One-Pass 大于1次则为 Multi-Pass 如果没有使用滋盘,则显示 OPTIMAL)
  OMem、lMem 为执行所需的内存评估值 ,OMem 为最优执行模式所需内存的评估值, lMem one-pass 模式所需内存的评估值。
  0/1/M  为最优 /one-pass/multipass 执行的次数。Used-Mem 为消耗的内存

 

 

 

 

 

 

 

  

版权声明:本文为yaohuiqin原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/yaohuiqin/p/11550989.html