`
streamsong
  • 浏览: 82198 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

结合AWR报告生成HTML格式的SQL执行计划

阅读更多

      有些时候,我们需要分析占用资源比较大的sql的执行计划,也需要将sql的执行计划以报告的形式反馈给客户,由于AWR报告里的SQL通常都是些变量,因此以命令行方式生成sql的执行计划就很麻烦,而且也不美观,利用awrsqrpt.sql脚本就很方便。

      生成HTML的执行计划很简单,如果是生成本地数据库的sql执行计划,执行awrsqrpt.sql就可以,但是如果需要生成由AWR迁移到本地数据库的分析数据,就需要使用awrsqrpi.sql。

SQL> @?/rdbms/admin/awrsqrpi

Specify the Report Type
~~~~~~~~~~~~~~~~~~~~~~~
Would you like an HTML report, or a plain text report?
Enter 'html' for an HTML report, or 'text' for plain text
Defaults to 'html'
输入 report_type 的值:  html

Type Specified:  html


Instances in this Workload Repository schema
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

   DB Id     Inst Num DB Name      Instance     Host
------------ -------- ------------ ------------ ------------
* 1520519778        1 STREAM       stream       STREAM
  2400249746        1 CNDERPDB     cnderpdb1    p5a1
  2400249746        2 CNDERPDB     cnderpdb2    p5b1

输入 dbid 的值:  2400249746       --输入要生成执行计划的数据库ID
Using 2400249746 for database Id
输入 inst_num 的值:  1                 --输入节点号
Using 1 for instance number


Specify the number of days of snapshots to choose from
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Entering the number of days (n) will result in the most recent
(n) days of snapshots being listed.  Pressing <return> without
specifying a number lists all completed snapshots.


输入 num_days 的值:  7

Listing the last 7 days of Completed Snapshots

                                                        Snap
Instance     DB Name        Snap Id    Snap Started    Level
------------ ------------ --------- ------------------ -----
cnderpdb1    CNDERPDB         50063 16 6月  2011 08:00     1
                              50064 16 6月  2011 09:00     1
                              50065 16 6月  2011 10:00     1
                              50066 16 6月  2011 11:00     1
                              50067 16 6月  2011 12:00     1

... ...

                              50206 22 6月  2011 07:00     1
                              50207 22 6月  2011 08:00     1
                              50208 22 6月  2011 09:00     1
                              50209 22 6月  2011 10:00     1

 

Specify the Begin and End Snapshot Ids
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
输入 begin_snap 的值:  50063               --输入开始快照号
Begin Snapshot Id specified: 50063

输入 end_snap 的值:  50209                  --输入结束快照号
End   Snapshot Id specified: 50209

 


Specify the SQL Id
~~~~~~~~~~~~~~~~~~
输入 sql_id 的值:  8hm5s0k011450      --在AWR报告中看到的占用资源较大的SQL ID
SQL ID specified:  8hm5s0k011450

Specify the Report Name
~~~~~~~~~~~~~~~~~~~~~~~
The default report file name is awrsqlrpt_1_50063_50209.html.  To use this name,

press <return> to continue, otherwise enter an alternative.

输入 report_name 的值:  d:\stream.html   --保存路径和名字

Using the report name d:\stream.html

Report written to d:\stream.html
SQL>

 

之后打开D盘下的stream.html就可以很直观的看到SQL_ID为8hm5s0k011450的执行计划

Stat Name Statement Total Per Execution % Snap Total
Elapsed Time (ms) 18,121,198 4.89 3.20
CPU Time (ms) 17,874,450 4.82 3.33
Executions 3,707,839    
Buffer Gets 404,447,392 109.08 3.85
Disk Reads 0 0.00 0.00
Parse Calls 6 0.00 0.00
Rows 9,831,284 2.65  
User I/O Wait Time (ms) 0    
Cluster Wait Time (ms) 0    
Application Wait Time (ms) 0    
Concurrency Wait Time (ms) 0    
Invalidations 0    
Version Count 38    
Sharable Mem(KB) 713    

 

Id Operation Name Rows Bytes Cost (%CPU) Time
0 SELECT STATEMENT       3 (100)  
1    FOR UPDATE          
2      SORT ORDER BY   1 32 3 (34) 00:00:01
3        TABLE ACCESS FULL TEMPSK 1 32 2 (0) 00:00:01
1
1
分享到:
评论

相关推荐

    如何使用AWR报告发现低效的SQL

    有了这些信息,DBA就可以着手优化这些SQL语句,比如通过添加合适的索引、重写SQL语句或调整数据库参数等方法来提高SQL执行效率,减少CPU和磁盘I/O的繁忙程度,最终提升整个系统的运行效率。 在优化过程中,DBA还...

    LINUX下AWR报告导出

    1. 使用`DBMS_WORKLOAD_REPOSITORY.AWR_REPORT_HTML`包生成HTML格式的AWR报告,例如: ``` @?/rdbms/admin/awrrpt.sql ``` 或者指定时间段(以快照ID为边界): ``` @?/rdbms/admin/awrrpt.sql -s 开始快照ID ...

    oracle生成Awr报告

    Elapsed Time(s)是SQL执行的总时间,Executions是执行次数。要计算每次执行的平均时间(Elapsed Time per Exec (s)),可以将Elapsed Time(s)除以Executions。 如果需要优化SQL性能,可以根据SQL ID在数据库中...

    AWR鹰眼系列AWR报告全面指标分析

    为了方便用户生成AWR报告,Oracle提供了相应的脚本工具,比如用于生成多个AWR报告的SQL脚本。此外,通过手动执行AWR快照的过程,用户可以更加灵活地控制报告的生成时机。具体命令如下: Exec dbms_workload_...

    ORACLE性能AWR报告的使用和分析[归纳].pdf

    3. 运行awrrpt.sql或awrrpti.sql脚本来生成报告,选择报告格式(HTML或文本)、指定快照时间范围以及报告保存的位置。 三、AWR报告分析 AWR报告包含关键指标,如Elapsed Time(总时间)和DB Time(数据库处理时间...

    oracle awr report 报告

    - SQL语句报告:详细的SQL执行统计,包括每条SQL的执行次数、总耗时、平均耗时、以及排序效率等。 - 时间模型:包括SQL执行时间和非SQL执行时间的细分,如硬解析、软解析、数据读取等。 4. AWR报告的作用:通过...

    ORACLE-AWR报告结果分析.pdf

    AWR通过定期(默认为每15分钟一次)创建快照(snapshot),收集系统资源使用情况、SQL执行统计等信息,并对比两次快照之间的差异,从而生成报告。这些快照数据存储在数据库的AWR表中。 2. **AWR报告内容**: - **...

    ORACLE-AWR报告结果分析.doc

    分析SQL执行计划,优化连接方式,避免全表扫描,以及合理利用索引都是优化策略的一部分。 总的来说,Oracle AWR报告提供了一种强大的工具来监测和诊断数据库性能问题。通过对报告的深入理解和分析,数据库管理员...

    awr阅读完整版附带案例

    Oracle AWR(Automatic Workload Repository)是Oracle数据库系统中一个重要的性能分析工具,它自动收集数据库的性能数据,包括SQL语句、等待事件、系统负载等,并生成详细报告,帮助DBA(数据库管理员)诊断和优化...

    分析所需要的AWR和ASH报告

    1. **实时会话行为**:查看特定时刻所有会话的状态,比如等待事件、SQL执行状态等。 2. **会话时间线**:分析会话在不同时间的行为模式,找出性能问题的精确时刻。 3. **会话等待事件的分布**:了解等待事件在不同...

    Oracle AWR与ASH性能报告深入解析

    - **生成报告**:可以使用Oracle Enterprise Manager (OEM)生成图形化的AWR报告,也可以通过SQL命令行或脚本自动生成HTML或TXT格式的AWR报告。例如,下面的命令可以生成一个AWR报告: ```sql BEGIN DBMS_WORKLOAD_...

    数据库SQL执行情况收集方法(1).docx

    2. 生成HTML格式的AWR报告,使用`select output from table(dbms_workload_repository.awr_report_html(DBID, INSTANCE_NUMBER, 报告起始时间snap_id, 报告结束时间snap_id));`,其中DBID、INSTANCE_NUMBER、snap_id...

    [Oracle] 分析AWR报告的方法介绍

    - **Top N SQL**:这部分显示了按时间、内存和I/O排序的前N个SQL语句,通过对这些SQL的执行计划分析,可以识别性能问题。 - **RAC Statistics**:在RAC环境中,需特别关注RAC统计信息,它们能揭示集群中的性能问题...

    Oracle调优工具使用研究.pdf

    AWR生成的报告可以是文本格式或默认的HTML格式,后者包含丰富的链接,便于用户深入分析。AWR报告提供了详细的性能指标,如SQL语句执行情况、等待事件、资源利用率等,帮助DBA定位性能瓶颈。 MYTUN则是另一种调优...

    采用JSP+Oracle开发的图片新闻发布系统

    4. **错误处理与异常捕获**:JSP可以捕获并处理在与数据库交互过程中可能出现的异常,如SQL执行失败、连接丢失等,确保系统的稳定运行。 5. **缓存机制**:为了提升性能,可以利用Oracle的缓存功能或第三方缓存库...

    最完整的Toad For Oracle使用手册

    - **SQL Optimizer with Toad**:展示了如何使用SQL Optimizer与Toad相结合优化SQL性能。 - **Benchmark Factory**:探讨了如何使用Benchmark Factory进行数据库负载测试。 - **Quest Code Tester Integration**:...

Global site tag (gtag.js) - Google Analytics