You might try placing the INSERT and SELECT CURRVAL into a transaction
block.-DEJ
> -----Original Message-----
> From: Patrick Welche [SMTP:prlw1@newn.cam.ac.uk]
> Sent: Thursday, April 29, 1999 1:05 PM
> To: pgsql-interfaces@postgreSQL.org
> Subject: [INTERFACES] sequences
>
> After the interesting discussion on what is the safest way to have a
> unique
> "oid"-like value per row, I thought I would have a go, but from libpq++ I
> don't seem to be able to read the new sequence value:
>
> Table = person
> +----------------------------------+----------------------------------+---
> ----+
> | Field | Type |
> Length|
> +----------------------------------+----------------------------------+---
> ----+
> | id | int4 not null default nextval('p |
> 4 |
> | surname | text not null |
> var |
> | firstname | text not null |
> var |
> | email | text |
> var |
> | phone | text |
> var |
> | rfbdate | date |
> 4 |
> +----------------------------------+----------------------------------+---
> ----+
> Index: person_id_key
>
> The output from my test program is:
>
> INSERT INTO person (surname,firstname,email,phone) VALUES
> ('Welche','Patrick','
> prlw1',null)
> SELECT currval('person_id_seq')
>
> Missing person id
>
> and the relevant bit of code is:
>
> query<<"INSERT INTO person (surname,firstname,email,phone) VALUES
> ('"
> <<a._surname<<"','"<<a._firstname<<"',"
> <<ISNULL(a._email)<<','
> <<ISNULL(a._phone)<<')'<<ends;
> s.send_query(query);
> query<<"SELECT currval('person_id_seq')"<<ends;
> s.send_query(query);
> if(s.Tuples()!=1)throw empty_result("Missing person id");
> a.id(toid(s.GetValue(0,"currval")));
>
> send_query prints the query and does a Exec(query). I suppose I don't
> understand the difference between doing things interactively in psql (the
> above INSERT and SELECT work then) and calling things from a program. Any
> tips?
>
> Cheers,
>
> Patrick