如何在pl / sql函数中的变量中存储多行?

时间:2018-01-16 10:03:52

标签: sql oracle plsql

我正在写一个pl / sql函数。我需要从select语句中选择多行:

    SELECT pel.ceid
    FROM pa_exception_list pel
    WHERE trunc(pel.creation_date) >= trunc(SYSDATE-7)

如果我使用:

SELECT pel.ceid
INTO v_ceid

它只存储一个值,但我需要存储此选择返回的所有值。鉴于这是一项功能,我不能只使用简单的选择,因为我收到错误," INTO - 是预期的。"

3 个答案:

答案 0 :(得分:1)

如果您确实需要存储多行,请检查BULK COLLECT INTO语句和示例。但也许FOR cursor LOOP和逐行处理将是更好的决定。

答案 1 :(得分:1)

您可以使用记录类型来执行此操作。以下示例应该适合您

c = a[:, b].swapaxes(0,1).reshape(-1,b.shape[1])

所以在你的情况下,它会像

DECLARE
    TYPE v_array_type IS VARRAY (10) OF NUMBER;
        var v_array;
BEGIN
    SELECT x
    BULK COLLECT INTO
        var 
    FROM (
            SELECT 1 x
            FROM dual
            UNION
            SELECT 2 x
            FROM dual
            UNION
            SELECT 3 x
            FROM dual
        );
        FOR I IN 1..3 LOOP
              dbms_output.put_line(var(I));
            END LOOP;

END;

答案 2 :(得分:0)

您可以将所有内容存储在rowtype参数中,并显示您要显示的列(假设ceid是您的主键列,col1& 2是一些您表中的其他列):

SQL> set serveroutput on;
SQL> declare
  l_exp pa_exception_list%rowtype;
begin
 for c in  (   select *
                 from pa_exception_list pel
                where trunc(pel.creation_date) >= trunc(SYSDATE-7) 
           ) -- to select multiple rows
 loop     
      select *
        into l_exp            
        from pa_exception_list
       where ceid = c.ceid; -- to render only one row( ceid is primary key )

      dbms_output.put_line(l_exp.ceid||' - '||l_exp.col1||' - '||l_exp.col2); -- to show the results     
 end loop;
end;
/