forall改写

最近更新时间: 2025-02-18 16:02:00

  • Oracle语法。
  • 复制
    复制成功
create table t5(f1 int,f2 int);
insert into t5 values(1,1);
insert into t5 values(2,2);
commit;

create table t6(f1 int,f2 int);

create or replace procedure p_forall is 
    TYPE t5list IS TABLE OF t5.f2%TYPE;
    t5s t5list;
BEGIN
    SELECT f2 BULK COLLECT INTO t5s FROM t5;    
    FORALL i IN t5s.FIRST .. t5s.LAST            
        insert into t6 values(t5s(i),t5s(i));   
    commit; 
END;
/
  • TDSQL-PG改写。
  • 复制
    复制成功
create or replace procedure p_forall is
    TYPE t5list IS TABLE OF t5.f2%TYPE;
    t5s t5list;
BEGIN
    SELECT f2 BULK COLLECT INTO t5s FROM t5;    
    FOR i IN t5s.FIRST .. t5s.LAST
    LOOP        
        insert into t6 values(t5s[i],t5s[i]);   
    END LOOP; 
    commit; 
END;
/