`

oracle10如何查出历史记录中执行效率低的SQL语句

阅读更多


解决oracle10g运行慢、无法确定瓶颈的问题,为了找到效率低的sql费劲不少,今天找到一个,

方法就是查看awr报告。

 

Oracle 在10g以前的使用的是 Statspack做性能故障诊断的。Oracle Database 10g 提供了一个显著改进的工具:自动工作负载信息库 (AWR)。
  Oracle 建议用户用这个取代 Statspack。AWR 实质上是一个 Oracle 的内置工具,和数据库一起安装。
  数据库装好后,快照由一个称为 MMON 的新的后台进程及其从进程自动地每小时采集一次(snap)
  它采集与性能相关的统计数据,并从那些统计数据中导出性能量度,以跟踪潜在的问题。

  为了节省空间,采集的数据在 7 天后自动清除。快照频率和保留时间都可以由用户修改。它产生两种类型的输出:文本格式(类似于 Statspack 报表的文本格式但来自于 AWR 信息库)和默认的 HTML 格式(拥有到部分和子部分的所有超链接),从而提供了非常用户友好的报表。

  AWR 使用几个表来存储采集的统计数据,所有的表都存储在新的名称为 SYSAUX 的特定表空间中的 SYS 模式下,并且以 WRM$_* 和 WRH$_* 的格式命名,H 代表“历史数据 (historical)”而 M 代表“元数据 (metadata)”。
  前一种类型(WRM$_*)存储元数据信息(如检查的数据库和采集的快照),
  后一种类型(WRH$_*)保存实际采集的统计数据。

  在这些表上构建了几种带前缀 DBA_HIST_ 的视图,这些视图可以用来编写您自己的性能诊断工具。
  视图的名称直接与表相关;例如,视图 DBA_HIST_SYSMETRIC_SUMMARY 是在WRH$_SYSMETRIC_SUMMARY 表上构建的。
  select t.view_name from dba_views t where t.view_name like 'DBA_HIST%'

  AWR 历史表采集的信息比 Statspack 多许多,这些信息包括表空间使用率、文件系统使用率、甚至操作系统统计数据。

 

 

具体操作方式:

登陆到服务器的操作系统;

进入到$ORACLE_HOME/rdbms/admin目录下;

然后sqlplus "/as sysdba"登陆到数据库,执行
@awrrpt.sql;

然后按照提示一步一步做,注意格式选html(这样方便你阅读)。

过程中需要设置以下值:
  report_type=html或text,enter采用默认为html
  num_days=1
  begin_snap=输入开始快照ID
  end_snap=输入结束快照ID
  report_name=输入要保存的文件名,enter采用默认文件名

Oracle默认1个小时产生一次快照,可以查看、修改这个频率,可以手工创建、删除快照。

完了之后,你把那个文件拷贝到本地用IE打开就看到了。里面有很详细的,包括这段时间占CPU,IO,等等最严重的SQL排行。比如“SQL ordered by Elapsed Time”列出耗费时间最长的sql。

 

 

==============一些资料=======================

1.查看当前的AWR保存策略、设置:快照间隔、保存时间。

    SQL> col SNAP_INTERVAL format a20
    SQL> col RETENTION format a20
    SQL> select * from dba_hist_wr_control;
          DBID SNAP_INTERVAL        RETENTION            TOPNSQL
    ---------- -------------------- -------------------- ----------
    262089084 +00000 01:00:00.0    +00007 00:00:00.0    DEFAULT

  以上结果表示,每小时产生一个SNAPSHOT,保留7天。

2.调整AWR配置,修改快照间隔和保存时间等。
  AWR配置都是通过dbms_workload_repository包进行配置。

  2.1 调整AWR产生snapshot的频率和保留策略,
  如将收集间隔时间改为30 分钟一次。并且保留5天时间(单位都是分钟):
  SQL> exec dbms_workload_repository.modify_snapshot_settings(interval=>30, retention=>5*24*60);
  设置快照时间间隔为 20 分钟,保留时间为两天 -- 您可以发出以下命令。参数以分钟为单位。
  SQL> exec dbms_workload_repository.modify_snapshot_settings ( interval => 20, retention => 2*24*60 );

  2.2 关闭AWR,把interval设为0则关闭自动捕捉快照
  SQL> exec dbms_workload_repository.modify_snapshot_settings(interval=>0);

  2.3 手工创建一个快照
  SQL> exec DBMS_WORKLOAD_REPOSITORY.CREATE_SNAPSHOT();
  exec dbms_workload_repository.create_snapshot;

  2.4 查看快照
  SQL> select * from sys.wrh$_active_session_history
  SQL> select count(*),max(snap_id) from wrh$_active_session_history;

  2.5 手工删除指定范围的快照
  SQL> exec DBMS_WORKLOAD_REPOSITORY.DROP_SNAPSHOT_RANGE(low_snap_id => 973, high_snap_id => 999, dbid => 262089084);

  2.6 创建baseline,保存这些数据用于将来分析和比较
  SQL> exec dbms_workload_repository.create_baseline(start_snap_id => 1003, end_snap_id => 1013, 'apply_interest_1');

  2.7 删除baseline
  SQL> exec DBMS_WORKLOAD_REPOSITORY.DROP_BASELINE(baseline_name => 'apply_interest_1', cascade => FALSE);

  2.8 将AWR数据导出并迁移到其它数据库以便于以后分析
  SQL> exec DBMS_SWRF_INTERNAL.AWR_EXTRACT(dmpfile => 'awr_data.dmp', mpdir => 'DIR_BDUMP', bid => 1003, eid => 1013);

  2.9 迁移AWR数据文件到其他数据库
  SQL> exec DBMS_SWRF_INTERNAL.AWR_LOAD(SCHNAME => 'AWR_TEST', dmpfile => 'awr_data.dmp', dmpdir => 'DIR_BDUMP');
  把AWR数据转移到SYS模式中:
  SQL> exec DBMS_SWRF_INTERNAL.MOVE_TO_AWR (SCHNAME => 'TEST');

  3.AWR报告日常分析

  3.1 SQL ordered by Elapsed Time
  记录了执行总和时间的TOP SQL(请注意是监控范围内该SQL的执行时间总和,而不是单次SQL执行时间 Elapsed Time = CPU Time + Wait Time)。

  Elapsed Time(S): SQL语句执行用总时长,此排序就是按照这个字段进行的。注意该时间不是单个SQL跑的时间,而是监控范围内SQL执行次数的总和时间。单位时间为秒。Elapsed Time = CPU Time + Wait Time
  CPU Time(s): 为SQL语句执行时CPU占用时间总时长,此时间会小于等于Elapsed Time时间。单位时间为秒。
  Executions: SQL语句在监控范围内的执行次数总计。
  Elap per Exec(s): 执行一次SQL的平均时间。单位时间为秒。
  % Total DB Time: 为SQL的Elapsed Time时间占数据库总时间的百分比。
  SQL ID: SQL语句的ID编号,点击之后就能导航到下边的SQL详细列表中,点击IE的返回可以回到当前SQL ID的地方。
  SQL Module: 显示该SQL是用什么方式连接到数据库执行的,如果是用SQL*Plus或者PL/SQL链接上来的那基本上都是有人在调试程序。一般用前台应用链接过来执行的sql该位置为空。
  SQL Text: 简单的sql提示,详细的需要点击SQL ID。

  3.2 SQL ordered by CPU Time:
  记录了执行占CPU时间总和时间最长的TOP SQL(请注意是监控范围内该SQL的执行占CPU时间总和,而不是单次SQL执行时间)。

  3.3 SQL ordered by Gets:
  记录了执行占总buffer gets(逻辑IO)的TOP SQL(请注意是监控范围内该SQL的执行占Gets总和,而不是单次SQL执行所占的Gets)。

  3.4 SQL ordered by Reads:
  记录了执行占总磁盘物理读(物理IO)的TOP SQL(请注意是监控范围内该SQL的执行占磁盘物理读总和,而不是单次SQL执行所占的磁盘物理读)。

  3.5 SQL ordered by Executions:
  记录了按照SQL的执行次数排序的TOP SQL。该排序可以看出监控范围内的SQL执行次数。

  3.6 SQL ordered by Parse Calls:
  记录了SQL的软解析次数的TOP SQL。说到软解析(soft prase)和硬解析(hard prase)见:http://www.taoyoyo.net/ttt/post/305.html

  3.7 SQL ordered by Sharable Memory:
  记录了SQL占用library cache的大小的TOP SQL。Sharable Mem (b):占用library cache的大小,单位是byte。

  3.8 SQL ordered by Version Count:
  记录了SQL的打开子游标的TOP SQL。

  3.9 SQL ordered by Cluster Wait Time:
  记录了集群的等待时间的TOP SQL

 

 

分享到:
评论

相关推荐

    oracle查看执行最慢与查询次数最多的sql语句

    在Oracle数据库管理中,了解SQL语句的执行性能和频率对于系统优化至关重要。本文将详细介绍如何查看Oracle数据库中执行最慢和查询次数最多的SQL语句,以帮助DBA(数据库管理员)识别潜在的性能瓶颈。 首先,我们来...

    Oracle数据库sql语句 跟踪器

    4. **历史记录**:存储SQL语句的历史执行信息,便于追踪性能变化趋势和问题的演变过程。 5. **对比分析**:比较不同时间段或不同版本的SQL执行性能,帮助识别性能提升或下降的原因。 6. **优化建议**:根据SQL语句...

    Oracle_SQL语句监视器

    7. **历史记录**: 除了实时监控,Oracle SQL语句监视器还记录了过去一段时间内的SQL活动,便于进行趋势分析和问题回溯。 在实际应用中,Oracle SQL语句监视器可以通过以下方式使用: - **调试**: 当遇到性能问题时...

    oracle中得到一条SQL语句的执行时间的两种方式

    总结来说,获取Oracle SQL语句的执行时间可以采用`SET TIMING ON`实时显示或者查询`V$SQL`视图来查看历史记录。前者适用于临时测试和调试,后者则更适合长期监控和性能分析。了解和掌握这两种方法,对于优化数据库...

    SQL优化 SQL优化软件 SQL优化工具

    当SQL语句执行效率低下时,可能导致数据库响应时间延长,服务器负载增加,甚至影响整个应用程序的性能。因此,SQL优化对于保持系统的高效运行至关重要。 SQL优化工具通常提供以下功能: 1. **查询分析**:这些工具...

    执行SQL语句的批处理

    用户可以创建批处理作业,设置定时执行,自动化日常维护任务,甚至可以监控执行状态和历史记录。 总的来说,Oracle SQL批处理是数据库管理员和开发人员不可或缺的工具,它简化了大量重复性工作,提高了工作效率,...

    oracle导出sql语句的结果集和保存执行的sql语句(深入分析)

    在Oracle数据库管理中,有时我们需要将SQL查询的结果集导出为文本文件,或者保存执行的SQL语句以供后续使用或记录。Oracle提供了一些实用的命令来实现这些功能,主要涉及`spool`和`sav`(或者`savelist`)这两个命令...

    Oracle SQL Monitor

    Oracle SQL Monitor是一款强大的数据库性能监控工具,主要用于跟踪和分析Oracle数据库中的SQL语句执行情况。在数据库管理和优化中,理解SQL语句的执行性能是至关重要的,因为这直接影响到数据库的响应时间和整体效率...

    Oracle的SQL监视工具SQLTracker

    这款工具在Oracle数据库环境中扮演着重要角色,它可以帮助用户实时监控SQL语句的执行情况,识别性能瓶颈,从而提高系统的整体效率。 在描述中提到,SQLTracker可以在Windows 11操作系统上直接运行,这意味着它可能...

    SQLTracker Oracle跟踪工具(支持64位)

    它不仅记录SQL语句的历史执行信息,还能分析出SQL的执行计划,帮助识别是否存在索引不当、全表扫描等问题。此外,通过对比不同时间段的性能数据,可以找出数据库性能变化的原因,为性能调优提供决策依据。 再者,...

    生成SQL语句工具

    在实际应用中,使用“生成SQL语句工具”不仅可以提高开发效率,还能确保SQL语句的准确性和可维护性。对于大型项目或团队协作,这类工具尤其重要,因为它们能保证所有团队成员遵循一致的编码规范和最佳实践。 总的来...

    sqlmonitor监控oracle,mysql,db2正在执行的sql

    SQLMONITOR是一款强大的数据库监控工具,它专门设计用于实时监控Oracle、MySQL和DB2数据库中正在执行的SQL语句。这个工具对于数据库管理员和开发人员来说极其重要,因为它可以帮助他们诊断性能问题,优化查询,以及...

    ORACLE SQL语句优化技术分析.rar

    6. **SQL Profile和SQL Plan Baseline**:Oracle 10g引入了SQL Profile,11g引入了SQL Plan Baseline,它们可以根据历史执行情况为SQL语句生成最佳执行计划,避免因数据分布改变导致的性能下降。 7. **绑定变量和...

    SQL语句生成及分析器 v2.0

    同时,它可能还提供性能分析,通过优化查询结构和建议使用索引等方式,提升SQL语句的执行效率。对于大型数据库应用来说,这一点至关重要,因为一个优化的SQL语句可以显著降低服务器负载,提高系统响应速度。 在...

    SQLTracker oracle跟踪工具

    在Oracle数据库管理中,SQL跟踪是一项至关重要的功能,它允许管理员监控数据库的性能,找出执行效率低下或者占用资源过多的SQL语句,从而进行优化。SQLTracker就是这样一款工具,它能够帮助我们有效地实现这一目标。...

    sql跟踪语句整理工具2

    1. **SQL语句捕获**:记录数据库系统执行的所有SQL语句,无论是来自应用程序还是直接通过数据库客户端。 2. **性能分析**:分析捕获到的SQL语句,提供查询执行时间、资源消耗等信息,帮助用户识别性能瓶颈。 3. **...

    oracle11g执行计划管理-(讲解如何固定sql的执行计划)

    1. **计划历史记录**(Plan History):对于执行超过一次的SQL语句,优化器会记录其每一次的执行计划及其相关信息,如SQL文本、绑定变量等,形成执行计划的历史记录。 2. **执行计划基准线**(Plan Baseline):这是...

    解决securecrt中sql语句上下键显示

    在使用SecureCRT进行远程连接到数据库时,特别是通过SQL*Plus工具执行SQL语句时,我们可能会遇到一个问题:使用上下箭头键来翻阅之前输入过的SQL命令时,SecureCRT无法正常显示这些历史记录。这种情况在Windows系统...

    SQL跟踪工具 Oracle 64位

    1. **SQL监视**:SQLTracker可以实时监控数据库中的SQL语句,记录每个查询的执行细节,包括执行时间、CPU使用率、I/O操作等,帮助识别慢查询和性能瓶颈。 2. **性能分析**:通过分析SQL语句的执行计划,SQLTracker...

    SQLTracker监视使用Oracle数据库的应用程序

    10. **历史记录**:SQLTracker通常会保存SQL语句的执行历史,便于回顾和对比,找出性能变化的原因。 综上所述,SQLTracker是一款强大的Oracle数据库监控工具,它为数据库管理提供了宝贵的洞察力,有助于保持系统的...

Global site tag (gtag.js) - Google Analytics