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#;
来查看每一条语句执行的时间,然后对具体的语句做出优化。