0
このコードを実行すると、結果は636790になりますが、63679が返されます。これに頭を打つ!なぜ失われた数字ですか?ソーステーブルと列は、最も簡単な方法は、ここで、SYS_REFCURSORを返すことです636790.Oracle PL/SQL Refカーソル機能がありません
create or replace package jt_types
as
type ttest is ref cursor;
end;
CREATE OR REPLACE FUNCTION jt_test
RETURN jt_types.ttest
IS
o_return jt_types.ttest;
BEGIN
OPEN o_return FOR
SELECT offn_id
FROM jt_offn_4
where offn_ID in (636790)
ORDER BY offn_id;
RETURN o_return;
END jt_test;
DECLARE
l_ids jt_types.ttest;
l_id NUMBER;
BEGIN
l_ids := jt_test;
LOOP
FETCH l_ids INTO l_id;
EXIT WHEN l_ids%NOTFOUND;
dbms_output.put_line('Rec: ' || l_id);
END LOOP;
CLOSE l_ids;
END;
'jt_types.ttest'が何かであることを私だと思いますなぜ'char(6)'のように? –