| From: | Alvaro Herrera <alvherre(at)commandprompt(dot)com> |
|---|---|
| To: | Gabriel Hermes Colina Zambra <hermeszambra(at)yahoo(dot)com> |
| Cc: | Edwin Quijada <listas_quijada(at)hotmail(dot)com>, systemguards(at)gmail(dot)com, listas(at)yoel(dot)com(dot)ar, pgsql-es-ayuda(at)postgresql(dot)org |
| Subject: | Re: OT , Obtener ID (PK) dese código VB6 con odbc |
| Date: | 2007-06-28 01:07:03 |
| Message-ID: | 20070628010703.GB561@alvh.no-ip.org |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-es-ayuda |
Gabriel Hermes Colina Zambra escribió:
> CREATE OR REPLACE FUNCTION "public"."fnc_deposito"
> (cdeposito varchar) RETURNS integer AS
> $body$
> declare
> cdeposito alias for $1;
> ndeposito integer;
> t2_row deposito_id_deposito_seq%ROWTYPE;
> BEGIN
> SELECT * into t2_row from deposito_id_deposito_seq;
> ndeposito:=t2_row.last_value+1;
> insert into deposito (deposito) select $1;
> return ndeposito;
> end;
> $body$
> LANGUAGE 'plpgsql' VOLATILE RETURNS NULL ON NULL INPUT
> SECURITY INVOKER;
Noooo! Esto esta malo. La manera correcta de obtener el valor de una
secuencia es nextval(); con currval() obtienes el valor mas reciente.
--
Alvaro Herrera http://www.CommandPrompt.com/
The PostgreSQL Company - Command Prompt, Inc.
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Alvaro Herrera | 2007-06-28 01:35:02 | Re: Ayuda con Update + Select |
| Previous Message | Gabriel Hermes Colina Zambra | 2007-06-28 00:39:15 | insert ......... returning ? |