对比 PL/SQL profiler 剖析结果

php中文网
发布: 2016-06-07 17:32:28
原创
1127人浏览过

使用PL/SQL PROFILER 剖析PL/SQL代码是快速定位PL/SQL代码段最有效的方法。在上一篇文章使用PL/SQL PROFILER 定位 PL/SQL 瓶颈代

使用pl/sql profiler 剖析pl/sql代码是快速定位pl/sql代码段最有效的方法。在上一篇文章使用pl/sql profiler 定位 pl/sql 瓶颈代码中描述了安装profiler,并给出了剖析的示例。本文参照了tom大师的代码来对比剖析前后的性能并附上其代码。

使用PL/SQL PROFILER 定位 PL/SQL 瓶颈代码 

1、用于实施剖析的存储过程

--环境
sys@USBO> select * from v$version where rownum

BANNER
------------------------------------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production

--用于实施剖析的原过程,下面是使用字面量的过程,注意代码中包含了启用与停止profiler
scott@USBO> create or replace procedure binds
  2  is
  3  v_num number;
  4  begin
  5  dbms_profiler.start_profiler('binds');
  6  for i in 1..100000 loop
  7    v_num := dbms_random.random;
  8    insert into t1 values (v_num,v_num);
  9  end loop;
 10  dbms_profiler.stop_profiler;
 11  end;
 12  /

Procedure created.

--用于实施剖析的原过程,下面是使用绑定量的过程,,注意代码中包含了启用与停止profiler
scott@USBO> create or replace procedure literals
  2  is
  3  v_num number;
  4  begin
  5  dbms_profiler.start_profiler('literals');
  6  for i in 1..100000 loop
  7    v_num := dbms_random.random;             
  8    execute immediate
  9      'insert into t1 values ('||v_num||','||v_num||')';
 10  end loop;
 11  dbms_profiler.stop_profiler;
 12  end;
 13  /

Procedure created.

--Author : Leshami
--Blog  :

--清除剖析表中的历史数据(每次剖析对比前执行)
scott@USBO> delete from plsql_profiler_data;

scott@USBO> delete from plsql_profiler_units;

scott@USBO> delete from plsql_profiler_runs;

--分别执行两个不同的过程
scott@USBO> exec literals;

scott@USBO> exec binds;

2、提取剖析对比结果

scott@USBO> @profsum

2 rows updated.

PL/SQL procedure successfully completed.

=
=
====================
total time

GRAND_TOTAL
-----------   
      58.93

=
=
====================
total time spent on each run

  RUNID RUN_COMMENT      SECS
------- ----------- ---------
      7 literals        53.19
      8 binds            5.75

=
=
====================
percentage of time in each module, for each run separately

  RUNID RUN_COMMENT UNIT_OWNER  UNIT_NAME          SECS PERCEN
------- ----------- ----------- -------------- --------- ------
      7 literals    SCOTT      LITERALS          53.19  100.0
      8 binds      SCOTT      BINDS              5.75  100.0

=
=
====================
percentage of time in each module, summarized across runs

UNIT_OWNER  UNIT_NAME          SECS PERCENTAG
----------- -------------- --------- ---------
SCOTT      LITERALS          53.19    90.25
SCOTT      BINDS              5.75      9.75

=
=
====================
lines taking more than 1% of the total time, each run separate

  RUNID    HSECS    PCT OWNER      UNIT_NAME      LINE# TEXT
------- --------- ------- ----------- -------------- ------ ---------------------
      7  5221.18    88.6 SCOTT      LITERALS            8 execute immediate
      8    502.97    8.5 SCOTT      BINDS              8 insert into t1 values
                                                            (v_num,v_num);

      7    73.04    1.2 SCOTT      LITERALS            7 v_num :=
                                                            dbms_random.random;

=
=
====================
most popular lines (more than 1%), summarize across all runs

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号