Oracle PLSQL BULK收集和For循环

时间:2015-01-06 10:54:58

标签: oracle plsql bulk-collect

我编写了以下oracle过程来批量获取数据并以块的形式处理它。我正在使用带有限制的批量收集选项来获取数据。但在for循环中我无法检索ORD_ID。我正在尝试使用

输出ORD_ID
DBMS_OUTPUT.put_line(l_orders(indx)); 

但在调用' PUT_LINE'""

时出现编译错误"错误的数字或参数类型
create or replace PROCEDURE TESTPROC AS 

CURSOR order_id_cur IS SELECT ORD_ID FROM orders ORDER BY ORD_ID ASC;
 l_order_id   VARCHAR2(100);
 TYPE orders_aat IS TABLE OF order_id_cur%ROWTYPE;
 l_orders orders_aat;
 limit_in NUMBER      :=10; 
 batch_in NUMBER :=0;


BEGIN
  OPEN order_id_cur;
  LOOP
    FETCH order_id_cur 
        BULK COLLECT INTO l_orders LIMIT limit_in;
    DBMS_OUTPUT.put_line('Batch-----'||batch_in);
    FOR indx IN 1 .. l_orders.COUNT 
    LOOP
        DBMS_OUTPUT.put_line(indx);
        DBMS_OUTPUT.put_line(l_orders(indx));
    END LOOP;

    EXIT WHEN l_orders.COUNT < limit_in;
    batch_in := batch_in+1;
   END LOOP;
   CLOSE order_id_cur;
END TESTPROC;

如何在for循环中获取ORD_ID的值。

2 个答案:

答案 0 :(得分:4)

这样做 -

DBMS_OUTPUT.put_line(l_orders(indx).ORD_ID);

例如,

SQL> DECLARE
  2  type t
  3  IS
  4    TABLE OF emp%rowtype;
  5    a t;
  6  BEGIN
  7    SELECT * BULK COLLECT INTO a FROM emp;
  8    FOR i IN 1..a.count
  9    LOOP
 10      dbms_output.put_line (a(i).ename);
 11    END LOOP;
 12  END;
 13  /
SMITH
ALLEN
WARD
JONES
MARTIN
BLAKE
CLARK
SCOTT
KING
TURNER
ADAMS
JAMES
FORD
MILLER

PL/SQL procedure successfully completed.

SQL>

答案 1 :(得分:0)

你也可以直接循环到下面的光标

FOR recc in order_id_cur 
   LOOP
       DBMS_OUTPUT.put_line(recc.ORD_ID );
   END LOOP;