分享
 
 
 

Oracle PL/SQL Profiler应用指南

王朝oracle·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

Oracle PL/SQL Profiler应用指南

Profiler是ORACLE PL/SQL 的一个调试优化跟踪方案的应用

相对sqltrace+tkprof工具调试优化跟踪方案来说, Profiler有最直观更方便的优点,因为不需要生成和读取服务器端的跟踪文件,它是将跟踪数据全部存储的数据库表里,所以也得到了一些第三方工具的支持,如PL/SQL DEVELOPER 。

注:Profiler生成的跟踪信息远远没有trace生成的具体,它没有执行计划、没有CPU及IO 信息,它只是生成主要的执行时间信息,所以分析起来比较快,比较直观,可以让我们以最快的时间定位要优化的SQL。

下面将介绍ORACLE PL/SQL profiler的具体应用

1、安装

安装总共要运行两个ORALCE自带的服务脚本

(1)、创建profiler的基础结构

@$ORACLE_HOME\rdbms\admin\proftab.sql;

proftab.sql会在当前用户下创建如下表结构及序列:

plsql_profiler_runs - profiler运行信息

plsql_profiler_units - profiler每个单元信息

plsql_profiler_data - profiler每个单元的具体数据

plsql_profiler_runnumber 用来生成profiler唯一运行编号的序列

(2)、创建数据库服务运行包

@$ORACLE_HOME\rdbms\admin\profload.sql;

profload.sql主要是创建sys.dbms_profiler包

包主要的函数过程有

start_profiler,

stop_profiler,

pause_profiler,

resume_profiler,

flush_data,

internal_version_check,

get_version,

rollup_unit,

rollup_run

主要使用的函数是

start_profiler--启动 profiler

stop_profiler--停止 profiler

其它为一些辅助函数

2、应用实例

declare

v_run_number integer;

v_temp1 integer;

begin

--1.启动profiler

sys.dbms_profiler.start_profiler(run_number => v_run_number);

--显示当前跟踪的运行序号(后面查询要用)

dbms_output.put_line('run_number:'v_run_number);

--2.运行要跟踪的PL/SQL

--select count(*) into v_temp1 from scott.emp t;

--select count(*) into v_temp1 from scott.dept t;

--3.停止profiler

sys.dbms_profiler.stop_profiler;

end;

3、查询结果

select u.unit_name,--单元名称

d.line,--代码行号

d.total_time,--总共运行时间(单位:10000亿分之一秒)

d.total_occur,--总共运行次数

d.min_time,--最小运行时间

d.max_time,--最大运行时间

s.text--源代码

from plsql_profiler_data d, sys.all_source s, plsql_profiler_units u

where d.runid = 33--运行号v_run_number

and u.runid = d.runid

and d.unit_number = u.unit_number

and d.total_occur <> 0

and s.type(+) = u.unit_type

and s.owner(+) = u.unit_owner

and s.name(+) = u.unit_name

and d.line# = nvl(s.line, d.line#)

order by u.unit_number, d.line#

以上介绍的是通过手工方法应用Profiler,使用相对比较烦杂,最后查询也不直观,下面将具体介绍在PL/SQL DEVELOPER 应用Profiler

1、 打开test window

方法一、新建一个test window

方法二、选择要跟踪运行的过程,快捷菜单test,如下图所示

在test window中输入你要执行的PL/SQL脚本

2、打开Profiler,如下图所示

假如在打开Profiler出现出错提示则说明你没有安装Profiler,具体安装步骤见上文的安装过程。

3、F8执行脚本,执行完成后,切换到profiler选项卡,如下图所示

每列的具体意义如下:

unit --单元名称

line--代码行号

total time--总共运行时间(本行代码的执行时间与最长代码执行时间的百分比图)

occurrences--总共运行次数

text--源代码

Average time—平均运行时间

maximum time--最大运行时间

minimum time--最小运行时间

列表中显示的源代码只显不一行,假如要定位则可以在对应的行中打开右键,选择

[Go to unit line] ,这样就会直接跳到对应的源代码位置。

工具栏

1、 显示配置对话框

2、 刷新

3、 删除当前运行号的数据

4、Run:显示当前的系统的所有Profiler列表,缺省为当前的跟踪

5、Unit:显示本次跟踪的单元列表信息(执行时间),缺省为所有单元的执行时间

配置PL/SQL Developer 的Profiler选项,如下图所示

Available Columns:可用列

Selected Columns:选择要查看的列

Time units:时间单位(秒、毫秒、微秒)

Show 0 occurrences:是否显示执行0次的处理语句

Graphical time display:用图形显示处理时间的颜色深度百分比

叶正盛

2005-04-17

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有