Re: Newbie: help with FUNCTION

Поиск
Список
Период
Сортировка
От Richard Huxton
Тема Re: Newbie: help with FUNCTION
Дата
Msg-id 421EDDE6.9040308@archonet.com
обсуждение исходный текст
Ответ на Newbie: help with FUNCTION  (Charl Gerber <charlgerber@yahoo.com>)
Список pgsql-general
Charl Gerber wrote:
> I'm trying to create  a function that takes 1
> paramater (eg an integer) as input, then does 5
> database updates or deletes in 5 different SQL
> statements and returns 5 integers (in one resultset)
> indicating how many rows were affected by the various
> updates/deletes.
>
> How do I do this?
>
> How can I specify the names of the 5 output colums?

Why not return 5 rows instead. That way you can extend it to 6 queries
easily.

CREATE TYPE num_rows_affected AS (
   tbl_name text,
   num_rows int4
);

CREATE FUNCTION do_stuff(int4) RETURNS SETOF num_rows_affected AS '
DECLARE
   res      num_rows_affected;
BEGIN
   -- Do query 1 here
   GET DIAGNOSTICS res.num_rows := ROW_COUNT;
   res.tbl_name := ''table1'';
   RETURN NEXT res;
   -- Do query 2 here
   GET DIAGNOSTICS res.num_rows := ROW_COUNT;
   res.tbl_name := ''table1'';
   RETURN NEXT res;
...etc...
   RETURN;
END;
' LANGUAGE plpgsql;


SELECT * FROM do_stuff(123);

Full details in the plpgsql chapter of the manuals. None of the above is
tested for syntax errors. You can use block-quoting in version 8.0

--
   Richard Huxton
   Archonet Ltd

В списке pgsql-general по дате отправления:

Предыдущее
От: Bruce Momjian
Дата:
Сообщение: Re: [PATCHES] A way to let Vacuum warn if FSM settings are low.
Следующее
От: Richard Huxton
Дата:
Сообщение: Re: Which query is less expensive / faster?