当前位置:  数据库>oracle

对比 PL/SQL profiler 剖析结果

    来源: 互联网  发布时间:2017-05-27

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

使用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 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  : http://www.linuxidc.com

--清除剖析表中的历史数据(每次剖析对比前执行)
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

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

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

PL/SQL procedure successfully completed.

=
=
====================
Number of lines actually executed in different units (by unit_name)

UNIT_OWNER  UNIT_NAME      LINES_EXECUTED LINES_PRESENT    PCT
----------- -------------- -------------- ------------- -------
SCOTT      LITERALS                    4            7    57.1
SCOTT      BINDS                      4            7    57.1

=
=
====================
Number of lines actually executed for all units

LINES_EXECUTED
--------------
            8

=
=
====================
total number of lines in all units

LINES_PRESENT
-------------
          14

推荐阅读:

使用PL/SQL执行java存储来获得MAC地址

在SQL中使用PL/SQL函数存在的问题

 

 

更多精彩内容请看下一页:


    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Docker监控以及cAdvisor和Prometheus监控工具的对比
  • 解析数据库分页的两种方法对比(row_number()over()和top的对比)
  • Oracle数据库对比工具 DBT
  • JS逐像素对比图片 IM.js
  • 在linux GNOME 下怎么调整显示器的 颜色 和对比度 ?
  • 搜索指定格式的文件,并将这些文件对比
  • JSP和ASP的对比资料,谁有啊?
  • shell对比文件内容脚本分享
  • Linux不同版本内核目录下的ChangeLog是以哪个版本作为对比?
  • jQuery 滑动对比插件 twentytwenty
  • 与MSSQL对比学习MYSQL的心得(三)--查看字段的长度
  • v4l2亮度 饱和度 对比度在videodev2.h中对应那个结构体啊?
  • 【百度分享】Socket通讯模块压力及大数据对比工具开发之aperlib(八)
  • 【百度分享】Socket通讯模块压力及大数据对比工具开发之aperlib(三)
  • stdio对比unistd仅仅是多了一层缓存么?
  • 请问在Unix/Linux上的套接字模型有那些,那些比较常用,Apache使用的是那个,谢谢?!如果能和Windows上的作对比就更好了
  • SQL中Charindex和Oracle中对应的函数Instr对比
  • 与MSSQL对比学习MYSQL的心得(四)--BLOB数据类型
  • Oracle不同数据库间对比分析脚本
  • mssql server 2012(SQL2012)各版本功能对比
  • 各系统之间的安全性对比


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,