From: | Filip Rembiałkowski <filip(dot)rembialkowski(at)gmail(dot)com> |
---|---|
To: | serviciotdf <serviciotdf(at)gmail(dot)com> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: Translate Function PL/pgSQL to SQL92 |
Date: | 2010-12-16 11:17:07 |
Message-ID: | AANLkTim3UH9Vbeva0TVhKBtyfUjeTCncjLMCv5nQRrXe@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
2010/12/16 serviciotdf <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 | Jean-David Beyer | 2010-12-16 14:38:42 | Re: Database consistency after a power shortage |
Previous Message | Samuel Gendler | 2010-12-16 07:58:16 | Re: Database consistency after a power shortage |