Вопрос по postgresql, plpgsql – plpgsql: вызов функции с двумя параметрами OUT

18

Я пытаюсь получить значения из функции plpgsql с двумя параметрами OUT, но у меня есть некоторые проблемы.

Это функции:

CREATE OR REPLACE FUNCTION get_test(OUT x text, OUT y text)
AS $$
BEGIN
   x := 1;
   y := 2;
END;
$$  LANGUAGE plpgsql;
----------------------------------------------------------------

CREATE OR REPLACE FUNCTION get_test_read()
RETURNS VOID AS $$
DECLARE
   xx text;
   yy text;
BEGIN

   SELECT get_test() INTO xx, yy;

   RAISE INFO 'x: <%>', xx;
   RAISE INFO 'y: <%>', yy;

END;
$$  LANGUAGE plpgsql;

Вывод команды:

select get_test_read();

INFO: x: <(1,2)

INFO: y: <>

get_test_read

Таким образом, оба значения переходят к первому параметру. Я не могу найти пример того, как вызывать такую функцию.

Ваш Ответ

1   ответ
30

OUT params, ваша функция вернетзапись.

Чтобы получить все значения, вы должны использовать функцию в качестве источника ваших данных и поместить их вFROM пункт, как это:

SELECT * FROM get_test() INTO xx, yy;
Извините, я забыл принять ответ marco
Хорошо, довольно просто, спасибо :) marco

Похожие вопросы