Re: How to script inserts where id is needed as fk - Mailing list pgsql-sql

From Jonathan S. Katz
Subject Re: How to script inserts where id is needed as fk
Date
Msg-id 05069440-C45F-4763-81A8-E14B5CB1CCB5@excoventures.com
Whole thread Raw
In response to How to script inserts where id is needed as fk  (Michael Schmidt <css.liquid@gmail.com>)
Responses Re: How to script inserts where id is needed as fk
List pgsql-sql
On Nov 8, 2013, at 2:44 PM, Michael Schmidt wrote:

> Hi guys,
>
> i need to script some insert statements. To simplify it a little bit so assume i got a
>
> table "User" and a table called "Article". Both tables have an serial id column. In "Articles" there is a column i
needto fill with the user id lets call it "create_user_id". 
>
> I want to do something like:
>
> Insert into User (name) values ('User1');
>
> Insert into Article ('create_user_id') values (1);
> Insert into Article ('create_user_id') values (1);
>
> Insert into User (name) values ('User2');
>
> Insert into Article ('create_user_id') values (2);
> Insert into Article ('create_user_id') values (2);
>
> So you see i have set it to 1 and 2 this not good cause it might not be 1 and 2.
> I probably need the id returned by the "insert into User" query to use it for the "insert into Article" query.

If you are on PG 9.1 and above, you can use a writeable CTE to do this:
WITH users AS (    INSERT INTO User (name)    VALUES ('user1')    RETURNING id)INSERT INTO Article
('create_user_id')SELECTidFROM users; 

Jonathan




pgsql-sql by date:

Previous
From: Michael Schmidt
Date:
Subject: How to script inserts where id is needed as fk
Next
From: Sergey Konoplev
Date:
Subject: Re: Query specific table using relative position in search path