From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | theofilu(at)eunet(dot)at |
Cc: | pgsql-interfaces(at)postgreSQL(dot)org |
Subject: | Re: [INTERFACES] ecpg and getting just assigned serial number |
Date: | 1999-09-12 16:01:41 |
Message-ID: | 2567.937152101@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-interfaces |
theofilu(at)eunet(dot)at (Theofilu Andreas) writes:
> to Informix's 'esqlc'. However. I have a table with a field of type
> 'serial'. Now I've no problem to insert any sentences into this table, but
> immediately after inserting a new sentence I need the newly assigned number
> to the serial field in the table. How can I access this number?
Postgres doesn't return that number automatically; you'll have to run a
separate query to find out what was inserted. You could do something
like
select serialcolumn from table where oid = NNNN;
since a single-row insert does return the OID of the inserted row.
(Note this will be pretty slow if the table is big and does not have
an index on OID.)
Another possibility is to execute nextval() for yourself and then insert
that result explicitly when you create the row. Still takes two queries,
though.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Theofilu Andreas | 1999-09-12 19:31:44 | Problem with character in strings |
Previous Message | Theofilu Andreas | 1999-09-12 14:25:17 | ecpg and getting just assigned serial number |