From: | serviciotdf <serviciotdf(at)gmail(dot)com> |
---|---|
To: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: Translate Function PL/pgSQL to SQL92 |
Date: | 2010-12-17 15:26:30 |
Message-ID: | 4D0B8126.1040300@gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Perfect!
The query worked fine!
Answer:
###
CREATE OR REPLACE FUNCTION pruebas(varchar, varchar, integer)
RETURNS void
AS
$delimiter$
INSERT INTO documentos(descripcion) SELECT $1
WHERE NOT EXISTS ( SELECT id FROM documentos WHERE descripcion = $1 );
INSERT INTO personal ( nombre, idtipodocumento, numdoc )
SELECT $2, ( SELECT id FROM documentos WHERE descripcion = $1 ), $3;
$delimiter$
LANGUAGE SQL;
###
Thanks Filip!
Marcelo
El 16/12/10 08:17, Filip Rembiałkowski escribió:
>
> 2010/12/16 serviciotdf <serviciotdf(at)gmail(dot)com
> <mailto:serviciotdf(at)gmail(dot)com>>
>
> Hello,
>
> I have a Function in PL/pgSQL and I need to translate it to SQL92,
> but I'm stuck.
>
> ###
> CREATE OR REPLACE FUNCTION pruebas(varchar, varchar, integer)
> RETURNS SETOF personal AS
> $delimiter$
> BEGIN
> PERFORM id from documentos WHERE descripcion = $1;
> IF NOT FOUND THEN
> INSERT INTO documentos(descripcion) VALUES($1);
> END IF;
> INSERT INTO personal(nombre,idtipodocumento,numdoc)
> VALUES($2, (SELECT id from documentos WHERE descripcion = $1), $3);
> END;
> $delimiter$
> LANGUAGE plpgsql;
> ###
>
> Tables
>
> CREATE TABLE documentos
> id serial NOT NULL,
> descripcion character varying(60),
> CONSTRAINT pkdocumentos PRIMARY KEY (id)
>
>
> CREATE TABLE personal
> id serial NOT NULL,
> nombre character varying(60),
> idtipodocumento smallint NOT NULL,
> numdoc integer,
> CONSTRAINT pkpersonal PRIMARY KEY (id),
> CONSTRAINT fkpdoc FOREIGN KEY (idtipodocumento)
> REFERENCES documentos (id) MATCH SIMPLE
> ON UPDATE CASCADE ON DELETE NO ACTION,
> CONSTRAINT unqnumdoc UNIQUE (idtipodocumento, numdoc)
>
>
>
> If I understand correctly, you mean translating this function into a
> sequence of plain SQL commands:
>
> INSERT INTO documentos(descripcion) SELECT $1
> WHERE NOT EXISTS ( SELECT id FROM documentos WHERE descripcion = $1 );
>
> INSERT INTO personal ( nombre, idtipodocumento, numdoc )
> SELECT $2, ( SELECT id FROM documentos WHERE descripcion = $1 ), $3;
>
> of course you will need to bind / pass parameters...
>
> HTH
>
> Filip
>
From | Date | Subject | |
---|---|---|---|
Next Message | acurtis416 | 2010-12-17 16:58:54 | Help with Function in plpgsql |
Previous Message | Achilleas Mantzios | 2010-12-17 10:19:11 | Full Text search differences from 8.3 to 8.4.6 |