Re: ignore unique violation OR check row exists

From: Zdravko Balorda <zdravko(dot)balorda(at)siix(dot)com>
To:
Cc: pgsql-sql(at)postgresql(dot)org
Subject: Re: ignore unique violation OR check row exists
Date: 2012-01-04 09:57:37
Message-ID: 4F042291.6040903@siix.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Andreas Kretschmer wrote:
> rverghese <riyav(at)hotmail(dot)com> wrote:
>
>> I want to insert a bunch of records and not do anything if the record already
>> exists. So the 2 options I considered are 1) check if row exists or insert
>> and 2) ignore the unique violation on insert if row exists.
>> Any opinions on whether it is faster to INSERT and then catch the UNIQUE
>> VIOLATION exception and ignore it in plpgsql versus check if row exists and
>> INSERT if it doesn't.
>> I can't seem to ignore the UNIQUE VIOLATION exception via php, since it is a
>> plpgsql command, so if I have to do the check and insert, alternatively i
>> have a function that tries to insert and then ignores the violation. I was
>> wondering if one way was better than the other.
>> Thanks

Take it out of transaction. Why is there a transaction in the first place?
If transaction is needed, ok, but take these inserts out and everything will
work as it should. Ignoring UNIQUE VIOLATION or any other error defeats the very
purpose of transaction. That's why you can't ignore it.

Zdravko

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Samuel Gendler 2012-01-04 10:09:54 Re: ignore unique violation OR check row exists
Previous Message Andreas Kretschmer 2012-01-04 09:08:38 Re: ignore unique violation OR check row exists