Re: How to catch the id in a INSERT INTO ... RETURNING function?

From: Gerhard Heift <ml-postgresql-20081012-3518(at)gheift(dot)de>
To: pgsql-general(at)postgresql(dot)org
Subject: Re: How to catch the id in a INSERT INTO ... RETURNING function?
Date: 2009-02-01 13:05:31
Message-ID: 20090201130531.GA6617@gheift
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general

On Sun, Feb 01, 2009 at 11:37:52AM +0100, A B wrote:
> Hi.
> I have a table foo(id serial primary key, b int); and I want an insert function
>
> create or replace function insert_to_foo(bvalue integer) returns integer as
> declare
> newindex integer;
> begin
> ... insert into foo (a,b) values (default,bvalue) returning id
> .... <---- THIS LINE
> -- do more with newindex here

INSERT INTO foo (a, b) VALUES (DEFAULT, bvalue) RETURNING id INTO newindex;

> return newindex;
> end;
>
>
> Well, the problem is that I want the id of the new post to be saved
> into the newindex variable for further actions. But how do I catch the
> value into the variable?
> Should I do:
>
> select id from insert into foo (a,b) values (default,bvalue) returning id;
> ?

See in the manual:
http://www.postgresql.org/docs/8.3/static/plpgsql-statements.html#PLPGSQL-STATEMENTS-SQL-ONEROW

Regards,
Gerhard

In response to

Browse pgsql-general by date

  From Date Subject
Next Message Osvaldo Kussama 2009-02-01 13:12:53 Re: ALTER TABLE with TYPE serial does not work
Previous Message Osvaldo Kussama 2009-02-01 13:04:18 Resp.: How to catch the id in a INSERT INTO ... RETURNING function?