Getting an ID inside a PostgreSQL transaction block
As an alternative to the INSERT ... RETURNING clause mentioned by Cody, you can use the current value the sequence associated with the ID column:
BEGIN;
INSERT INTO albums [...];
INSERT INTO album_images (currval('albums_id_seq'), image_id) [...];
COMMIT;
This assumes the standard naming scheme from Postgres when creating the sequence automatically for columns defined as serial
.
Another alternative - if you are only using a single insert - is to use the lastval()
function. You would then not even need to put the sequence name into the INSERT statement:
BEGIN;
INSERT INTO albums [...];
INSERT INTO album_images (lastval(), image_id) [...];
COMMIT;