• ORACLE学习笔记性能优化6


    21.什么是STATSPACK,我怎么使用它?
      Statspack是Oracle 8i以上提供的一个非常好的性能监控与诊断工具,基本上全部包含了BSTAT/ESTAT的功能,更多的信息,可以参考附带文档$ORACLE_HOME/rdbms/admin/spdoc.txt。

      安装Statspack:
      cd $ORACLE_HOME/rdbms/admin
      sqlplus "/ as sysdba" @spdrop.sql -- 卸载,第一次可以不需要
      sqlplus "/ as sysdba" @spcreate.sql -- 需要根据提示输入表空间名

      使用Statspack:
      sqlplus perfstat/perfstat
      exec statspack.snap; -- 进行信息收集统计,每次运行都将产生一个快照号
      -- 获得快照号,必须要有两个以上的快照,才能生成报表
      select SNAP_ID, SNAP_TIME from STATS$SNAPSHOT;
      @spreport.sql -- 输入需要查看的开始快照号与结束快照号

      其他相关脚本s:
      spauto.sql - 利用dbms_job提交一个作业,自动的进行STATPACK的信息收集统计
      sppurge.sql - 清除一段范围内的统计信息,需要提供开始快照与结束快照号
      sptrunc.sql - 清除(truncate)所有统计信息


    22. SQL语句的优化方法
      <1> /*+ALL_ROWS*/
      表明对语句块选择基于开销的优化方法,并获得最佳吞吐量,使资源消耗最小化.
      例如:
      SELECT /*+ALL+_ROWS*/ EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE EMP_NO='CCBZZP';

      <2>. /*+FIRST_ROWS*/
      表明对语句块选择基于开销的优化方法,并获得最佳响应时间,使资源消耗最小化.
      例如:
      SELECT /*+FIRST_ROWS*/ EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE    EMP_NO='CCBZZP';

      <3>. /*+CHOOSE*/
      表明如果数据字典中有访问表的统计信息,将基于开销的优化方法,并获得最佳的吞吐量;
      表明如果数据字典中没有访问表的统计信息,将基于规则开销的优化方法;
      例如:
      SELECT /*+CHOOSE*/ EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE EMP_NO='CCBZZP';

      <4>. /*+RULE*/
      表明对语句块选择基于规则的优化方法.
      例如:
      SELECT /*+ RULE */ EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE EMP_NO='CCBZZP';  

      <5>. /*+FULL(TABLE)*/
      表明对表选择全局扫描的方法.
      例如:
      SELECT /*+FULL(A)*/ EMP_NO,EMP_NAM FROM BSEMPMS A WHERE EMP_NO='CCBZZP';

      <6>. /*+ROWID(TABLE)*/
      提示明确表明对指定表根据ROWID进行访问.
      例如:
      SELECT /*+ROWID(BSEMPMS)*/ * FROM BSEMPMS WHERE ROWID>='AAAAAAAAAAAAAA'
       AND EMP_NO='CCBZZP';

      <7>. /*+CLUSTER(TABLE)*/
      提示明确表明对指定表选择簇扫描的访问方法,它只对簇对象有效.
      例如:
      SELECT  /*+CLUSTER */ BSEMPMS.EMP_NO,DPT_NO FROM BSEMPMS,BSDPTMS
      WHERE DPT_NO='TEC304' AND BSEMPMS.DPT_NO=BSDPTMS.DPT_NO;

      <8>. /*+INDEX(TABLE INDEX_NAME)*/
      表明对表选择索引的扫描方法.
      例如:
      SELECT /*+INDEX(BSEMPMS SEX_INDEX) USE SEX_INDEX BECAUSE THERE ARE FEWMALE    BSEMPMS */  FROM BSEMPMS WHERE SEX='M';

      <9>. /*+INDEX_ASC(TABLE INDEX_NAME)*/
      表明对表选择索引升序的扫描方法.
      例如:
      SELECT /*+INDEX_ASC(BSEMPMS PK_BSEMPMS) */  FROM BSEMPMS WHERE DPT_NO='CCBZZP';

      <10>. /*+INDEX_COMBINE*/
      为指定表选择位图访问路经,如果INDEX_COMBINE中没有提供作为参数的索引,将选择出位图索引的
      布尔组合方式.
      例如:
      SELECT /*+INDEX_COMBINE(BSEMPMS SAL_BMI HIREDATE_BMI)*/ * FROM BSEMPMS
      WHERE SAL<5000000 AND HIREDATE<SYSDATE;

      <11>. /*+INDEX_JOIN(TABLE INDEX_NAME)*/
      提示明确命令优化器使用索引作为访问路径.
      例如:
      SELECT /*+INDEX_JOIN(BSEMPMS SAL_HMI HIREDATE_BMI)*/ SAL,HIREDATE
      FROM BSEMPMS WHERE SAL<60000;

      <12>. /*+INDEX_DESC(TABLE INDEX_NAME)*/
      表明对表选择索引降序的扫描方法.
      例如:
      SELECT /*+INDEX_DESC(BSEMPMS PK_BSEMPMS) */  FROM BSEMPMS WHERE    DPT_NO='CCBZZP';

      <13>. /*+INDEX_FFS(TABLE INDEX_NAME)*/
      对指定的表执行快速全索引扫描,而不是全表扫描的办法.
      例如:
      SELECT /*+INDEX_FFS(BSEMPMS IN_EMPNAM)*/ * FROM BSEMPMS WHERE DPT_NO='TEC305';

  • 相关阅读:
    烯烃(olefin) 题解
    二分图的考验 题解
    树上的好题
    [SDOI2013]直径 题解
    [ZJOI2010]数字计数 题解
    神在夏至祭降下了神谕 题解
    洛谷 P4198 楼房重建 题解
    [HAOI2010]软件安装 题解
    [POI2011]ROT-Tree Rotations 题解
    可并堆之左偏树浅谈
  • 原文地址:https://www.cnblogs.com/einyboy/p/2493525.html
Copyright © 2020-2023  润新知