Re: Skip dups on INSERT instead of generating an error ...

From: Tomasz Myrta <jasiek(at)klaster(dot)net>
To: "Marc G(dot) Fournier" <scrappy(at)postgresql(dot)org>
Cc: pgsql-sql(at)postgresql(dot)org
Subject: Re: Skip dups on INSERT instead of generating an error ...
Date: 2003-12-12 21:33:36
Message-ID: 3FDA3430.3010007@klaster.net
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Dnia 2003-12-12 21:53, Użytkownik Marc G. Fournier napisał:

> I need to be able to run an INSERT INTO / SELECT FROM UNION which combines
> two tables into one ... *but* ... the INTO table has a primary key on the
> first column, so if the result of the UNION generates dups, by default, of
> course, it will generate errors ... what I'd like is to have it so that it
> just skips over those records.
>
> First thought would be to write a quite plpgsql function that would do a
> SELECT first, to see if the value already exists, and if not, then do the
> INSERT ... but am wondering if maybe there is a cleaner way that I'm not
> thinking of?

What kind of dups are you talking about? UNION eliminates duplicates by
default as described in documentation.

If you want to eliminate only primary key duplicates, you can use
distinct and subselects:

insert into table3
select distinct on (some_id) * from
(select * from table1 union
select * from table2) x;

Another way to eliminate such duplicates is creating simple pl/pgsql
insert trigger which checks dups before inserting new rows and returns
NULL if some row already exists.

Regards,
Tomasz Myrta

In response to

Browse pgsql-sql by date

  From Date Subject
Next Message pginfo 2003-12-13 07:10:16 Interest IN problem on 7.4
Previous Message scott.marlowe 2003-12-12 21:03:10 Re: Skip dups on INSERT instead of generating an error ...