mirror of
https://github.com/postgres/postgres.git
synced 2025-05-12 16:21:30 +03:00
> >Luckily, PG 8 is available for this. Do you have a short example?
> > No, and I think it should be in the manual as an example. > > You will need to enter a loop that uses exception handling to detect > unique_violation. Pursuant to an IRC discussion to which Dennis Bjorklund and Christopher Kings-Lynne made most of the contributions, please find enclosed an example patch demonstrating an UPSERT-like capability. David Fetter
This commit is contained in:
parent
7cce39c7ce
commit
bd32a25598
@ -1,5 +1,5 @@
|
|||||||
<!--
|
<!--
|
||||||
$PostgreSQL: pgsql/doc/src/sgml/plpgsql.sgml,v 1.65 2005/04/07 14:53:04 tgl Exp $
|
$PostgreSQL: pgsql/doc/src/sgml/plpgsql.sgml,v 1.66 2005/04/19 03:37:20 momjian Exp $
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<chapter id="plpgsql">
|
<chapter id="plpgsql">
|
||||||
@ -2103,6 +2103,40 @@ END;
|
|||||||
don't use <literal>EXCEPTION</> without need.
|
don't use <literal>EXCEPTION</> without need.
|
||||||
</para>
|
</para>
|
||||||
</tip>
|
</tip>
|
||||||
|
<example id="plpgsql-upsert-example">
|
||||||
|
<para>
|
||||||
|
This example uses an <literal>EXCEPTION</> to <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>
|
</sect2>
|
||||||
</sect1>
|
</sect1>
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user