首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Oracle在for循环中提交

Oracle在for循环中提交
EN

Stack Overflow用户
提问于 2019-02-18 17:09:39
回答 3查看 2.2K关注 0票数 0

我有一个使用for-loop的过程,用于将行从外部表插入到普通表中。该表大约有6-7列。现在我在每个插入上都提交了,这需要大约20分钟来插入4个4mill记录。是否可以在每1k行或每5k行上使用commit进行优化

代码语言:javascript
运行
复制
if mod(i,5000)=0 then
commit;

下面是循环现在的样子:

代码语言:javascript
运行
复制
FOR i IN 1..arr.COUNT
                    LOOP
                      begin
                              INSERT  INTO A(...)
                              values( ...);

                              commit;
                        end;
                   END LOOP;
EN

回答 3

Stack Overflow用户

发布于 2019-02-18 17:38:12

一种方法是使用模函数:

代码语言:javascript
运行
复制
for i in 1 .. arr.count loop
  begin
    insert  into a (...)
    values ( ...);

    if mod(i, 5000) = 0 then
      commit;
    end if;
  end;

  commit;
end loop;

但是,从游标中按块读取数据并使用FORALL通常要好得多。不过,我不知道使用外部表是否可以做到这一点。

代码语言:javascript
运行
复制
declare
  type type_table_of_sometable_rows is table of sometable%rowtype;
  v_array type_table_of_sometable_rows;
  cursor mycursor is select * from sometable;
begin
  open mycursor;
  loop
    fetch mycursor bulk collect into v_array limit 5000;
    exit when v_array.count = 0;
    forall i in 1 .. v_array.count
      insert into mytable values ( v_array(i).col1, v_array(i).col2) );
    commit;
  end loop;
end;
票数 1
EN

Stack Overflow用户

发布于 2019-02-19 03:40:07

不如..。

代码语言:javascript
运行
复制
Insert into table
Select * from external_table;
Commit;
票数 1
EN

Stack Overflow用户

发布于 2019-02-18 17:44:36

代码语言:javascript
运行
复制
CURSOR xxx IS  
   SELECT 
     *
      FROM table t
      where t.id='abc';    
  for Viewxxx in xxx loop
     -- Add  logic here! 
  end loop;              
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54743742

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档