从具有OUT参数的函数返回

时间:2013-12-24 14:44:42

标签: postgresql return-value user-defined-functions plpgsql

我有错误,但我不知道问题是什么。

我想执行一个函数并从列默认列表中填充的列中返回一个值 - 一个序列 - 相当于currval(sequence)

我用:
PostgreSQL 9.0
pgAdmin III

CREATE OR REPLACE FUNCTION name_function(in param_1 character varying
                                      , out param_2 bigint)
  AS
$$
BEGIN
    INSERT INTO table (collumn_seq,param_1) VALUES (DEFAULT,param_1)
    returning collumn_seq;
--where:collumn_seq reference a collumn serial..
END;
$$
  LANGUAGE plpgsql VOLATILE;

我可以无错误地创建函数,但在尝试执行时,会返回以下错误:

SELECT name_function('GHGHGH');

ERROR: The query has no destination for result data

1 个答案:

答案 0 :(得分:2)

它会像这样工作:

CREATE OR REPLACE FUNCTION name_function(param_1 character varying
                                   , OUT param_2 bigint) AS
$func$
BEGIN
    INSERT INTO table (collumn_seq, param_1)
    VALUES (DEFAULT, param_1)
    RETURNING collumn_seq
    INTO param2;
END
$func$ LANGUAGE plpgsql;

通常情况下,您会添加RETURN语句,但OUT参数为{{1}},这是可选的。
有关详细信息,请参阅手册: