diff options
author | Neil Conway | 2005-10-06 21:21:27 +0000 |
---|---|---|
committer | Neil Conway | 2005-10-06 21:21:27 +0000 |
commit | 20f5a328e5a81e175d8dc864713b8c266d26a210 (patch) | |
tree | 0455d0753eae32b5efe4fb31d7ae8bee72eac746 /doc/src | |
parent | ce150c4a8b1cf12dde8cb9629d864be849c5d187 (diff) |
Backpatch merge_db() example for PL/PgSQL to 8.0. Patch from David
Fetter, fixes by Neil Conway.
Diffstat (limited to 'doc/src')
-rw-r--r-- | doc/src/sgml/plpgsql.sgml | 40 |
1 files changed, 39 insertions, 1 deletions
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 @@ <!-- -$PostgreSQL: pgsql/doc/src/sgml/plpgsql.sgml,v 1.57.4.1 2005/01/22 23:05:47 momjian Exp $ +$PostgreSQL: pgsql/doc/src/sgml/plpgsql.sgml,v 1.57.4.2 2005/10/06 21:21:27 neilc Exp $ --> <chapter id="plpgsql"> @@ -1998,6 +1998,44 @@ END; don't use <literal>EXCEPTION</> without need. </para> </tip> + + <example id="plpgsql-upsert-example"> + <title>Exceptions with <command>UPDATE</>/<command>INSERT</></title> + <para> + + + This example uses exception handling to perform either + <command>UPDATE</> or <command>INSERT</>, as appropriate. + +<programlisting> +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'); +</programlisting> + + </para> + </example> </sect2> </sect1> |