首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将多行存储在pl/sql函数中的变量中?

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

Stack Overflow用户
提问于 2018-01-16 10:03:51
回答 3查看 13.6K关注 0票数 1

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

代码语言:javascript
复制
    SELECT pel.ceid
    FROM pa_exception_list pel
    WHERE trunc(pel.creation_date) >= trunc(SYSDATE-7)

如果我用:

代码语言:javascript
复制
SELECT pel.ceid
INTO v_ceid

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

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-01-16 10:09:39

您可以使用记录类型来做到这一点。下面的示例应该适用于您

代码语言:javascript
复制
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;

所以在你的情况下,你会觉得

代码语言:javascript
复制
select pel.ceid 
  BULK COLLECT INTO <variable which you create>
  from pa_exception_list
 where trunc(pel.creation_Date) >= trunc(sysdate-7);
票数 3
EN

Stack Overflow用户

发布于 2018-01-16 10:07:44

如果确实需要存储多行,请检查散装装进语句和示例。但是,也许用于游标循环和逐行处理将是更好的决定。

票数 2
EN

Stack Overflow用户

发布于 2018-01-16 10:49:22

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

代码语言:javascript
复制
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;
/   
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48278638

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档