PL/SQL-如何使用游标的所有列插入表

Posted

技术标签:

【中文标题】PL/SQL-如何使用游标的所有列插入表【英文标题】:PL/SQL- How to insert into a table using all columns of a cursor 【发布时间】:2017-10-20 07:16:15 【问题描述】:

我正在使用游标在表中插入数据,因为如果记录失败,我只想丢弃该记录并继续插入其余记录。

所以我使用光标来检索信息。

有没有办法一次插入光标的所有列而不是一一选择?

 cursor c1 is 
select a,b,c,d,e from ab where a = 'something';

begin
for var_c1 in c1  loop 
begin

insert into ba (a,b,c,d,e) 
values (var_c1.all);

-- instead of values (var_c1.a, var_c1.b, var_c1.c,var_c1.d, var_c1.e) 
exception when others then continue;
end;

end;

【问题讨论】:

我会建议你做一些阅读,这肯定会帮助你自己解决你的问题。阅读此oracle.com/technetwork/issue-archive/2012/12-sep/… 【参考方案1】:

为了提高性能,您应该将所有记录放入一个集合中,然后您可以使用 BULK INSERT... SAVE EXCEPTION,如下所示:

DECLARE
  TYPE t_tab IS TABLE OF ba%ROWTYPE;

  l_tab          t_tab := t_tab();
  l_error_count  NUMBER;

  ex_dml_errors EXCEPTION;
  PRAGMA EXCEPTION_INIT(ex_dml_errors, -24381);
BEGIN
  -- Fill the collection.  ***
  -- l_tab  <--- ??
  -- *** next question is to make l_tab fill with the result of your cursor    
  --
  -- Perform a bulk operation.
  BEGIN
    FORALL i IN l_tab.first .. l_tab.last SAVE EXCEPTIONS
      INSERT INTO ba
      VALUES l_tab(i);
  EXCEPTION
    WHEN ex_dml_errors THEN
      l_error_count := SQL%BULK_EXCEPTIONS.count;
      DBMS_OUTPUT.put_line('Number of failures: ' || l_error_count);
      FOR i IN 1 .. l_error_count LOOP
        DBMS_OUTPUT.put_line('Error: ' || i || 
          ' Array Index: ' || SQL%BULK_EXCEPTIONS(i).error_index ||
          ' Message: ' || SQLERRM(-SQL%BULK_EXCEPTIONS(i).ERROR_CODE));
      END LOOP;
  END;
END;
/

希望对你有帮助

【讨论】:

以上是关于PL/SQL-如何使用游标的所有列插入表的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 pl/sql 中的游标将多列数据插入包含单列的表中?

如何传递从多个表创建的 PL/SQL 游标记录?

使用回滚/提交关闭所有游标,如何克服

如何在 Pl/SQL 中正确创建一个过程,在该过程中我创建一个表并使用一个游标

将新列添加到现有表中并使用 PL/SQL 中游标中的值更新它们

如何在 PL/SQL 中增量集成数据