Oracle runstats_pkg 过程性能比较
来源:互联网 发布:编程儿童产业 编辑:程序博客网 时间:2024/06/01 09:47
select 'latch'||name name,gets from v$latch;
上面是创建stats视图;
② create global temporary table run_stats(runid varchar2(15),name varchar2(80),value int) on commit preserve rows/delete rows;
这是创建全局临时表;
③ 下面创建runstats_pkg包:
create or replace package runstats_pkg as
procedure rs_start;
procedure rs_middle;
procedure rs_stop(p_diffrence_threshold in number default 0);
end;
④ 接着创建包体:
create or replace package body runstats_pkg as
g_start number;
g_run1 number;
g_run2 number;
procedure rs_start
as
begin
delete from run_stats;
insert into run_stats select 'before',name,value from stats;
g_start:=dbms_utility.get_time;
end;
procedure rs_middle
as
begin
g_run1:=(dbms_utility.get_time-g_start);
insert into run_stats select 'after 1',name,value from stats;
g_start:=dbms_utility.get_time;
end;
procedure rs_stop(p_diffrence_threshold in number default 0)
as
begin
g_run2:=(dbms_utility.get_time-g_start);
dbms_output.put_line('Run1 ran in'||g_run1||'hsecs');
dbms_output.put_line('Run2 ran in'||g_run2||'hsecs');
dbms_output.put_line('run1 ran in'||round((g_run1/g_run2)/100,2)||'% of the time');
dbms_output.put_line(chr(9));
insert into run_stats select 'after 2',stats.* from stats;
dbms_output.put_line(lpad('Name',30)||lpad('Run1',10)||lpad('Run2',10)||lpad('Diff',10));
for x in
(select lpad(a.name,30)||
to_char((b.value-a.value),'9,999,999')||
to_char((c.value-b.value),'9,999,999')||
to_char(((c.value-b.value)-(b.value-a.value)),'9,999,999') data
from run_stats a,run_stats b,run_stats c
where a.name=b.name
and
a.name=b.name
and
c.name=b.name
and
a.runid='before'
and
b.runid='after 1'
and
c.runid='after 2'
and
(c.value-a.value)>0
and
abs((c.value-b.value)-(b.value-a.value))>p_diffrence_threshold
order by abs((c.value-b.value)-(b.value-a.value))
)
loop
dbms_output.put_line(x.data);
end loop;
dbms_output.put_line(chr(9));
dbms_output.put_line('Run1 latches total versus runs -- diffrence and pct');
dbms_output.put_line(lpad('Run1',10)||lpad('Run2',10)||lpad('Diff',10)||lpad('Pct',8));
for x in
(select to_char(run1,'9,999,999')||
to_char(run2,'9,999,999')||
to_char(diff,'9,999,999')||
to_char(round(run1/run2*100,2),'9,999,999')||
'%' data
from (select sum(b.value-a.value) run1,sum(c.value-b.value) run2,sum((c.value-b.value)-(b.value-a.value)) diff
from run_stats a,run_stats b,run_stats c
where a.name=b.name and
b.name=c.name and
a.runid='before'
and b.runid='after 1'
and c.runid='after 2'
and a.name like 'LATCH%'
) )
loop
dbms_output.put_line(x.data);
end loop;
end;
end;
/
⑤ 再下面我们开始使用runstas_pkg包:
㈠ create table test as select * from dba_objects where 1=0;
㈡ exec runstats_pkg.rs_start;
㈢ insert into test select * from dba_objects;
commit;
㈣ exec runstats_pkg.rs_middle;
㈤ begin
for x in (select * from dba_objects) loop
insert into test values x;
end loop;
commit;
end;
㈥ exec runstats_pkg.rs_stop;
- Oracle runstats_pkg 过程性能比较
- Oracle runstats_pkg 过程性能比较
- RUNSTATS_PKG 测试存储过程性能和效率
- ORACLE insert 性能比较
- Oracle分析存储过程性能
- 分页存储过程性能比较 二分法
- SQL与Oracle、DB2的性能比较
- Oracle中子查询与Join性能比较
- Oracle常用分页语句性能比较
- Oracle数据库日期过滤方法性能比较
- Oracle 日期过滤方法性能比较
- runstats_pkg PACKAGE --Thomas Kyte
- 一个Oracle GeoSQL性能问题解决过程
- 常用存储过程分页实现方法的性能比较
- row_number()分页和存储过程分页性能比较
- SQL Server分页的存储过程写法以及性能比较
- php+mysql中存储过程性能简单比较
- 存储过程性能测试之_Sql执行速度的比较
- 引用传参--面向对象的魅力
- jsp常用的九个内置对象总结
- 机器猫500集下载
- UITableView可编辑状态常用操作
- java包装类
- Oracle runstats_pkg 过程性能比较
- 以前的他
- 对话框通知
- 自动化的倚天剑QTP(一)
- GenericJDBCException: could not insert: [com.sns.bean.User]
- 如何从函数中获取动态内存
- 【内存池系列】我的内存池设计(更新中)
- NonUniqueResultException: query did not return a unique result: 2
- DOS的MD和RD命令使用说明