对比 PL/SQL profiler 剖析结果

使用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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1879450.html

(0)
上一篇 2025年2月22日 10:58:27
下一篇 2025年2月22日 10:58:42

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Oracle 11g中的Native PL/SQL代码编译

    Oracle环境中,PL/SQL是我们进行业务逻辑实现的最佳手段,同时也是和Oracle数据库本身结合的最好的语言。使用好PL/SQL本身功能, oracle环境中,pl/sql是我们进行业务逻辑实现的最佳手段,同时也是和oracle数据库…

    数据库 2025年2月23日
    100
  • Oracle EBS

    版本:Tested on R12.0.6/R12.1.1,注意:请根据具体环境调整GUEST用户密码,默认情况都是ORACLE。 GUEST用户的密码可以在$CONTEX 版本:tested on r12.0.6/r12.1.1 注意:请根…

    数据库 2025年2月22日
    100
  • 一段Oracle EBS中给指定用户增加指定职责的PLSQL脚本

    在一些比较注重权限的EBS项目中, 普通用户通常没有System Administrator权限, 只能由DBA给一个一个用户一个一个职责加, 纯手工的 一段oracle ebs中给指定用户增加指定职责的plsql脚本 [日期:2012-1…

    数据库 2025年2月22日
    100
  • SQL和PL/SQL中绑定变量的区别

    在Oracle 中,对于一个提交的sql语句,存在两种可选的解析过程, 一种叫做硬解析,一种叫做软解析.一个硬解析需要经解析,制定执行路 在oracle 中,对于一个提交的sql语句,存在两种可选的解析过程, 一种叫做硬解析,一种叫做软解析…

    数据库 2025年2月22日
    100
  • 使用PLSQL 打印日历

    最近有些闲,看完了concept突然有种空虚的感觉。闲话不多说。 用PLSQL写了一个打印日历的功能。 create or replace package disp 最近有些闲,,看完了concept突然有种空虚的感觉。闲话不多说。 用PL…

    数据库 2025年2月22日
    100
  • PLSQL 连接 Oracle简单配置

    PLSQL工作依赖于 OCI.DLL 和其他一些Client带的文件,所以必须提供.通过环境变量 TNS_ADMIN找到LISTENER.ORA, tnsnames.oRA,从而建 思路: plsql工作依赖于 oci.dll 和其他一些c…

    数据库 2025年2月22日
    100
  • PL/SQL PLS_INTEGER类型对性能实验测试

    如果用PLS_INTEGER值运算,Oracle会使用原生机器算法其他的所有数值型的数据类型都和NUMBER数据类型一样使用C语言算法库结果就是 如果用pls_integer值运算,,oracle会使用原生机器算法 其他的所有数值型的数据类…

    数据库 2025年2月22日
    100
  • Oracle PL/SQL 浅析IF和ELSIF的不平等

    之前写过一篇文章,叫:Oracle PL/SQL 从if 到 then的ldquo;艺术鉴赏rdquo;,地址:http://www.linuxidc.com/Linux/2013-01/77 之前写过一篇文章,叫:oracle pl/sq…

    数据库 2025年2月22日
    100
  • Oracle自带的PL/SQL Developer导入导出数据

    最近使用oracle导入导出数据时,遇到了不少的麻烦!遂对oracle数据库进行了认真的学习,总结了几种导入导出的命令方法,以备以后 最近使用oracle导入导出数据时,遇到了不少的麻烦!遂对oracle数据库进行了认真的学习,总结了几种导…

    数据库 2025年2月22日
    100
  • PL/SQL: ORA-00942: table or view does not exist

    在用户jytest下可以直接查询jytest1.test表但是在jytest下创建一个过程,在过程中引用jytest1.test表编译不通过.在过程中引用别的 有两个用户jytest,jytest1都拥有dba权限在jytest1用户创建了…

    数据库 2025年2月22日
    100

发表回复

登录后才能评论