我正在编写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它只存储一个值,但我需要存储此选择返回的所有值。考虑到这是一个函数,我不能仅仅使用简单的选择,因为我得到了错误,“ is -是预期的”。
发布于 2018-01-16 10:09:39
您可以使用记录类型来做到这一点。下面的示例应该适用于您
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);发布于 2018-01-16 10:07:44
如果确实需要存储多行,请检查散装装进语句和示例。但是,也许用于游标循环和逐行处理将是更好的决定。
发布于 2018-01-16 10:49:22
您可以将所有内容存储在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;
/ https://stackoverflow.com/questions/48278638
复制相似问题