Deferrable UNIQUE INDEX? - Mailing list pgsql-hackers

From David Fetter
Subject Deferrable UNIQUE INDEX?
Date
Msg-id 20060104014512.GA27483@fetter.org
Whole thread Raw
Responses Re: Deferrable UNIQUE INDEX?
Re: Deferrable UNIQUE INDEX?
List pgsql-hackers
Folks,

I just stumbled across a little problem that looks like this:

CREATE TABLE foo (   id SERIAL PRIMARY KEY,   f_text TEXT NOT NULL
);

CREATE UNIQUE INDEX uniq_foo_f_text ON foo(LOWER(TRIM(f_text)));

COPY foo(f_text) FROM stdin;
a
b
c
\.

Oh, shucks.  I'd like to permute these.  Lemme start a transaction:

test@[local]=> BEGIN;
BEGIN
test@[local]=> UPDATE foo set f_text = 'a' where id=3;
ERROR:  duplicate key violates unique constraint "uniq_foo_f_text"

Dang!  Everything was going to be kosher at the end of the
transaction, but I never got a chance.

Is there some way to make the index check INITIALLY DEFERRABLE the way
a regular column/table constraint could be?

I'd much appreciate any insights into this :)

Cheers,
D
-- 
David Fetter david@fetter.org http://fetter.org/
phone: +1 415 235 3778

Remember to vote!


pgsql-hackers by date:

Previous
From: Josh Berkus
Date:
Subject: Inconsistent syntax in GRANT
Next
From: "Andrew Dunstan"
Date:
Subject: Re: Deferrable UNIQUE INDEX?