Re: get sequence value of insert command - Mailing list pgsql-sql

From Passynkov, Vadim
Subject Re: get sequence value of insert command
Date
Msg-id C8C8E7457059D5119E4700D0B765DCB8016AA912@sinope.inside.pathcom.com
Whole thread Raw
In response to get sequence value of insert command  (Erik Thiele <erik@thiele-hydraulik.de>)
List pgsql-sql
> > > create sequence mysequence;
> > > 
> > > create table foo(
> > >   id integer default nextval('mysequence'),
> > >   bla text,
> > >   wombat integer,
> > >   foobar date,
> > >   primary key(id)
> > > );
> > > 
> > > insert into foo (wombat) values (88);
> > > 
> > > now how do i know the id of my newly inserted element? and
> > > how can this be done in a completely concurrency safe way?
> > 
> > CREATE RULE get_pkey_on_insert AS ON INSERT TO foo DO SELECT
> > currval('mysequence') AS id LIMIT 1;
> 
> now that one is really great! you should definitly add it to the
> faq. plus an additional explanation why the limit 1 is needed here.

INSERT INTO foo ( ... ) ( SELECT * FROM foo1 );

> 
> thanks!
> erik
> 

-- 
Vadim Passynkov


pgsql-sql by date:

Previous
From: Rod Taylor
Date:
Subject: Re: Doubt :- Image_Insert
Next
From: Richard Rowell
Date:
Subject: Recursive SETOF function