批量提交

create or replace procedure clean_alarminfo_histroy
--批量提交:为节省执行时间和效率增加了删除批量提交
as
pragma autonomous_transaction;
n_delete number:=0;
p_count number:=3000;
begin
insert into alarminfohistory
select *
from alarminfo b
where b.iscleared=1
and b.arrivetime <to_date(to_char(sysdate,'yyyy-mm-dd'),'yyyy-mm-dd')
/* and not exists (select alarmnumber
from alarminfohistory
where b.alarmnumber = alarmnumber)*/;
commit;
while 1=1 loop
EXECUTE IMMEDIATE
'delete from alarminfo where iscleared=1 and arrivetime<to_date(to_char(sysdate,'||'''||yyyy-mm-dd||'''||'),'||'''||yyyy-mm-dd||'''||') and rownum <= :rn'
USING p_Count;
if SQL%NOTFOUND then
exit;
else
n_delete:=n_delete + SQL%ROWCOUNT;
end if;
commit;
end loop;
commit;
DBMS_OUTPUT.PUT_LINE('Finished!');
DBMS_OUTPUT.PUT_LINE('Totally '||to_char(n_delete)||' records deleted!');
end clean_alarminfo_histroy;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值