【实验】oracle剖析存储过程性能

导言:
在日常oracle开发中有时候一个存储过程执行的时间很长,想要定位存储过程的性能问题时最笨的办法是打开存储过程一行行的肉眼看哪一行sql,可能存在问题。

从oracle 8i开始提供了一个profiler工具用于剖析存储过程的性能问题。但是前提是安装了相应的包。

安装方法:
1、sys用户执行
/u01/app/oracle/product/11.2.0/db_1/rdbms/admin/profload.sql

2、在要剖析存储过程的所属用户下执行,会创建plsql_profiler_runs、plsql_profiler_units、plsql_profiler_data三张表
/u01/app/oracle/product/11.2.0/db_1/rdbms/admin/proftab.sql
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
3、做好了以上2步以后,我们就可以开始分析存储过程了

declare

Vresult binary_integer;

begin

Vresult := dbms_profiler.start_profiler(run_comment => ‘fanjun’ ||sysdate);
sp_createNE(‘fanjun’,111);
Vresult := dbms_profiler.stop_profiler;

end;

/

这是用我自己的一个存储过程测试的结果:
在这里插入图片描述
在all_source中查看存储过程的12行代码信息
select A.line ||’:’ ||A.TEXT
from all_source a
where a.OWNER = ‘IM’
AND A.name = UPPER(‘sp_createNE’);
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值