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

Posted

技术标签:

【中文标题】如何在 pl/sql 函数中的变量中存储多行?【英文标题】:How to store multiple rows in a variable in pl/sql function? 【发布时间】:2018-01-16 10:03:51 【问题描述】:

我正在编写一个 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

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

【问题讨论】:

【参考方案1】:

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

DECLARE
    TYPE v_array_type IS VARRAY (10) OF NUMBER;
        var v_array_type;
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;

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

select pel.ceid 
  BULK COLLECT INTO <variable which you create>
  from pa_exception_list
 where trunc(pel.creation_Date) >= trunc(sysdate-7);

【讨论】:

【参考方案2】:

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

【讨论】:

【参考方案3】:

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

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;
/   

【讨论】:

以上是关于如何在 pl/sql 函数中的变量中存储多行?的主要内容,如果未能解决你的问题,请参考以下文章

PL/SQL编程_概述

如何编写 PL 以返回通过服务总线中的 DB 适配器自动生成强类型 XSD 的多行? (甲骨文 PL/SQL)

PL_sql如何执行oracle存储过程

PL/SQL中如何查看变量的类型?

如何使用输入参数创建 PL/SQL 存储过程以返回数据集

如何在 pl/sql 过程中使用游标返回多行和多列?