Oracle分页提交

–数据量如果超过30万要采用分段提交的方式。若表数据量达到千万级,可10w一批提交。
declare
cursor mycursor is
select rowid row_id, --获取rowid
sidec,
id --PK字段
from SIDE_T t
where t.SIDEA = 100;
type t_data is table of mycursor%rowtype;
v_data t_data;
begin
open mycursor;
loop
fetch mycursor bulk collect
into v_data limit 10000; --10000行提交一次
exit when v_data.count = 0;
forall i in v_data.first … v_data.last
update SIDE_T
set SIDEC = ‘更新’
where rowid = v_data(i).row_id; --通过rowid更新记录方式
–where id = v_data.id; --通过PK更新记录方式
commit;
end loop;
close mycursor;
end;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值