幾千行對 oracle 來說不是問題,可以一次提交
專注于為中小企業(yè)提供網(wǎng)站制作、成都網(wǎng)站建設服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)達茂旗免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上1000家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
如果一定要這么做,有兩種方式:
一,用游標打開,一行拼一個insert 語句,并計數(shù);滿100后提交
二,分頁查詢,每頁100行 ,然后提交
我覺得:能一次提交的盡量不要分開提交,如果提交到一部分時候,出現(xiàn)問題了,提交的不能回滾了。增加了業(yè)務邏輯的復雜性。
begin
v_cnt number:=0;
loop
delete from a where rownum=100000;
v_cnt:=SQL%ROWCOUNT;
commit;
exit when v_cnt=0;
end loop;
end;
不明白所謂的分批。如果是數(shù)據(jù)量太大,可以考慮寫procedure,通過for 循環(huán),將資料一部分一部分存放到本地,然后在再本地表里查詢。這個方法當然是對于少量表來說,比較方便快捷。如果是大量的表,可以考慮使用replication 或stream
Oracle中有三種循環(huán)(For、While、Loop):
1、loop循環(huán):
create?or?replace?procedure?pro_test_loop?is
i?number;
begin
i:=0;
loop
i:=i+1;
dbms_output.put_line(i);
if?i5?then
exit;
end?if;
end?loop;
end?pro_test_loop;
2、while循環(huán):
create?or?replace?procedure?pro_test_loop??is
i?number;
begin
i:=0;
while?i5?loop
i:=i+1;
dbms_output.put_line(i);
end?loop;
end?pro_test_loop;
3、for循環(huán)1:
create?or?replace?procedure?pro_test_for?is
i?number;
begin
i:=0;
for?i?in?1..5?loop
dbms_output.put_line(i);
end?loop;
end?pro_test_for;
4、for循環(huán)2:
create?or?replace?procedure?pro_test_cursor?is
userRow?t_user%rowtype;
cursor?userRows?is
select?*?from?t_user;
begin
for?userRow?in?userRows?loop
dbms_output.put_line(userRow.Id||','||userRow.Name||','||userRows%rowcount);
end?loop;
end?pro_test_cursor;
文章標題:oracle怎么循環(huán)分批,oracle如何分批提交
地址分享:http://www.rwnh.cn/article24/dscogje.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供域名注冊、網(wǎng)站制作、企業(yè)建站、定制開發(fā)、電子商務、網(wǎng)站設計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)