使用DBMS_PROFILER调整PL/SQL的性能

Key Words

Oracle 9i

PL_SQL

DBMS_PROFILER

 

最近开发的一个项目中,使用了大量的PL_SQL来编写存储过程处理数据。

 

上线前,需要对PL_SQL做一些性能优化。

 

于是使用了DBMS_PROFILER包来完成这个任务。

 

如何使用可以参考:http://space.itpub.net/11220451/viewspace-509955 这篇文章。

 

可以使用

SELECT   d.line#,               --代码行号
s.text,                                --源代码
d.total_time/1000.00/1000.00/1000.00,                   --总共运行时间(单位10000亿分之一秒)
d.total_occur,                  --总共运行次数
d.min_time,                     --最小运行时间
d.max_time,                     --最大运行时间
u.unit_name           
FROM   plsql_profiler_data d, sys.all_source s, plsql_profiler_units u
WHERE  d.runid = 24           --运行号
--and u.unit_name = 'Unite_POSP'        --单元名,即被测试的存储过程名
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#;
 来查看每一条语句执行的时间,然后对具体的语句做出优化。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值