From: Neil Conway Date: Thu, 6 Oct 2005 21:21:27 +0000 (+0000) Subject: Backpatch merge_db() example for PL/PgSQL to 8.0. Patch from David X-Git-Tag: REL8_0_5~38 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=20f5a328e5a81e175d8dc864713b8c266d26a210;p=thirdparty%2Fpostgresql.git Backpatch merge_db() example for PL/PgSQL to 8.0. Patch from David Fetter, fixes by Neil Conway. --- diff --git a/doc/src/sgml/plpgsql.sgml b/doc/src/sgml/plpgsql.sgml index 731fc9b9c4d..bed224ab6db 100644 --- a/doc/src/sgml/plpgsql.sgml +++ b/doc/src/sgml/plpgsql.sgml @@ -1,5 +1,5 @@ @@ -1998,6 +1998,44 @@ END; don't use EXCEPTION without need. + + + Exceptions with <command>UPDATE</>/<command>INSERT</> + + + + This example uses exception handling to perform either + UPDATE or INSERT, as appropriate. + + +CREATE TABLE db (a INT PRIMARY KEY, b TEXT); + +CREATE FUNCTION merge_db(key INT, data TEXT) RETURNS VOID AS +$$ +BEGIN + LOOP + UPDATE db SET b = data WHERE a = key; + IF found THEN + RETURN; + END IF; + + BEGIN + INSERT INTO db(a,b) VALUES (key, data); + RETURN; + EXCEPTION WHEN unique_violation THEN + -- do nothing + END; + END LOOP; +END; +$$ +LANGUAGE plpgsql; + +SELECT merge_db(1, 'david'); +SELECT merge_db(1, 'dennis'); + + + +