小编Jes*_*sse的帖子

从Oracle函数返回表

我已经在这里看了很多解决方案,试图解决这个问题,他们已经走得很远,但现在我正处于一些错误的杂草中,我似乎无法过去.

我在Oracle 11g上.我需要一个函数来返回一个记录集(表).这是我正在使用的代码:

CREATE TYPE T_TABLE IS OBJECT
(
    Field1 int
    , Field2 int
);

CREATE TYPE T_TABLE_COLL IS TABLE OF T_TABLE;

CREATE OR REPLACE FUNCTION FN_MyFunction
RETURN T_TABLE_COLL 
IS
BEGIN
  FOR I IN (SELECT Field1, Field2 FROM Table1) LOOP
    IF I.Field1 = 1 THEN
        BEGIN           
            INSERT INTO T_TABLE     
            SELECT Field1, Field2
            FROM Table2
            WHERE Field2 = I.Field2;
        END;
    ELSIF I.Field1 = 2 THEN
        BEGIN           
            INSERT INTO T_TABLE     
            SELECT Field1, Field2
            FROM Table2
            WHERE Field2 = I.Field2;
        END;  
  END IF; …
Run Code Online (Sandbox Code Playgroud)

oracle plsql function oracle11g

3
推荐指数
1
解决办法
3万
查看次数

从集合1 ... 49中生成6个不重复的数字

我需要生成6个数字而不重复从1到49.我有类似的东西:

create table zadanie1(
NAZWISKO varchar2(30),
PUNKTY number,
ID number,
constraint stud1_nazw primary key(NAZWISKO)
);



create or replace procedure "LOTTO" IS
pkt number;
begin
   loop
       BEGIN
       pkt := round(dbms_random.value(1,14),0);
       INSERT INTO ZADANIE1(PUNKTY) VALUES (pkt);
       exit;
       Exception When DUP_VAL_ON_INDEX Then 0;
       END;
end loop;
END;
Run Code Online (Sandbox Code Playgroud)

但这似乎不起作用.有人能帮助我吗?

sql oracle

3
推荐指数
1
解决办法
194
查看次数

标签 统计

oracle ×2

function ×1

oracle11g ×1

plsql ×1

sql ×1