您是存儲過程的新手。 正在使用與Oracle存儲過程幫助
select * from table into var
無功動態SQL是一種variable.the變種中包含多個值,當我嘗試運行與輸入的PROC我得到一個錯誤:
ORA-01422: exact fetch returns more than requested number of rows
有一種使變量可以使用動態sql保存多行的方式。
您是存儲過程的新手。 正在使用與Oracle存儲過程幫助
select * from table into var
無功動態SQL是一種variable.the變種中包含多個值,當我嘗試運行與輸入的PROC我得到一個錯誤:
ORA-01422: exact fetch returns more than requested number of rows
有一種使變量可以使用動態sql保存多行的方式。
您可以使用表變量,它爲您提供結果的內存表。聲明表變量類似於標準的變量:
declare @MyVar table (col1 col1type, col2 col2type, etc.)
使用集合變量:
DECLARE
TYPE tt_int IS TABLE OF INTEGER;
var tt_int;
BEGIN
SELECT id
BULK COLLECT
INTO var
FROM table;
END;
你必須bulk collect
結果集爲table of
類型,如果你要選擇多行。
declare
type record_type is table of <table_name>;
var_records record_type;
begin
select *
bulk collect into var_records
from <table_name>;
end;
/
,你還可以將結果返回到ref cursor
set serveroutput on
DECLARE
REFEXAMPLE SYS_REFCURSOR;
VAR NUMBER ;
col varchar2(50);
BEGIN
OPEN REFEXAMPLE FOR --Here you open the cursor and fill it
SELECT *
FROM (
SELECT 1 VAR, 'a' COL FROM DUAL
UNION ALL
SELECT 2 VAR, 'b' COL FROM DUAL
UNION ALL
SELECT 3 VAR, 'c' COL FROM DUAL
UNION ALL
SELECT 4 VAR, 'd' COL FROM DUAL
UNION ALL
SELECT 5 VAR, 'e' COL FROM DUAL
) EXAMPLETABLE ;
DBMS_OUTPUT.PUT_LINE('var ' || 'col');
DBMS_OUTPUT.PUT_LINE('---------');
LOOP
FETCH REFEXAMPLE INTO VAR, col; --now loop through
EXIT WHEN REFEXAMPLE%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(var || ' ' || col || ' ');
END LOOP;
CLOSE REFEXAMPLE;
end ;
/
var col
---------
1 a
2 b
3 c
4 D
5 e
我們可以看到您的存儲過程? – 2011-01-19 13:55:59
Kassos to Quassnoi將Oracle標識爲僅來自ORA-01422錯誤消息文本的數據庫。 – APC 2011-01-19 14:05:46