Re: Updating a unique constrant - Mailing list pgsql-general

From Bruno Wolff III
Subject Re: Updating a unique constrant
Date
Msg-id 20040607041758.GC17952@wolff.to
Whole thread Raw
In response to Updating a unique constrant  ("Peter Rahm-Coffey" <RahmCoff@radio1190.org>)
Responses Re: Updating a unique constrant
List pgsql-general
On Fri, Jun 04, 2004 at 13:09:40 -0600,
  Peter Rahm-Coffey <RahmCoff@radio1190.org> wrote:
>
> If current_play is less than 94, I get uniqueness error. Since the update
> is most likely to be done when playorder = 1, this is a problem. I
> switched to the slower numeric to try doing insert values (1+1/123), but
> then I can't do SELECT ... WHERE playorder = 1.00813008130081. (It returns
> false.) Is there a way out of my problem without removing the unique index
> and the foreign keys that use it?

Uniqueness constraints can't be deferred. One common strategy is to change
all of the values to values in a set disjoint from what they are now union
with what they will be. (Commonly people make the negative of their
current value.) And then change them to the correct new values.

pgsql-general by date:

Previous
From: Bruno Wolff III
Date:
Subject: Re: COPY error handling
Next
From: Bruno Wolff III
Date:
Subject: Re: Concurrent access related issue.