Re: how to insert multiple rows and get the ids back in a temp table (pgplsql)? - Mailing list pgsql-general

From Bret Green
Subject Re: how to insert multiple rows and get the ids back in a temp table (pgplsql)?
Date
Msg-id 735430.31920.qm@web120406.mail.ne1.yahoo.com
Whole thread Raw
In response to Re: how to insert multiple rows and get the ids back in a temp table (pgplsql)?  (Alban Hertroys <dalroi@solfertje.student.utwente.nl>)
List pgsql-general
No I do need it inside pgplsql. I need pgplsql for other stuff.


From: Alban Hertroys <dalroi@solfertje.student.utwente.nl>
To: Bret Green <bret.green@yahoo.com>
Cc: pgsql-general@postgresql.org
Sent: Sun, September 19, 2010 9:25:46 AM
Subject: Re: [GENERAL] how to insert multiple rows and get the ids back in a temp table (pgplsql)?

On 19 Sep 2010, at 3:43, Bret Green wrote:

> how can I do the following in plpgsql?
>
> insert multiple rows in a table
>
> get the ids (serial) into a temp table (not the client)
>

> for one row it will be like this
>
> insert into mytable(mycolumn)values(123)returning id into some_variable;

You can do that for multiple rows just fine, you don't even need plpgsql for that:

development=> \d test
    Table "public.test"
Column |  Type  | Modifiers
--------+---------+-----------
i      | integer |

development=> INSERT INTO test (i) select x from generate_series(4, 10) t(x) ret
urning i;

----
  4
  5
  6
  7
  8
  9
10
(7 rows)

INSERT 0 7


Alban Hertroys

--
If you can't see the forest for the trees,
cut the trees and you'll see there is no forest.


!DSPAM:1170,4c96399610251136218112!



pgsql-general by date:

Previous
From: Thom Brown
Date:
Subject: Re: Database not starting up for hot standby
Next
From: Bret Green
Date:
Subject: Re: how to insert multiple rows and get the ids back in a temp table (pgplsql)?