Re: Unique index problem - Mailing list pgsql-general

From Scott Marlowe
Subject Re: Unique index problem
Date
Msg-id CAOR=d=12=ksrRaYMyBQ=5aaajke5zp7vr-Ske-zuAcNpjVq9aQ@mail.gmail.com
Whole thread Raw
In response to Re: Unique index problem  (Scott Marlowe <scott.marlowe@gmail.com>)
Responses Re: Unique index problem  (Marc Mamin <M.Mamin@intershop.de>)
List pgsql-general
On Sun, Dec 20, 2015 at 9:00 AM, Scott Marlowe <scott.marlowe@gmail.com> wrote:
> On Sun, Dec 20, 2015 at 8:50 AM, Sterpu Victor <victor@caido.ro> wrote:
>> Hello
>>
>> I created a unique index that doesn't seem to work when one column is NULL.
>> Index is created like this: CREATE UNIQUE INDEX lab_tests_groups_siui_uni ON
>> lab_tests_groups_siui(id_lab_tests_siui, id_lab_tests_groups, valid_from,
>> id_lab_sample_types);
>> Now I can run this insert twice and I will have 2 records in the database
>> that seem to violate this index:
>> INSERT INTO lab_tests_groups_siui(id_lab_tests_siui, id_lab_tests_groups,
>> valid_from) VALUES(463, 9183, '2014-06-01');
>>
>> When I create the index like this "CREATE UNIQUE INDEX
>> lab_tests_groups_siui_uni ON lab_tests_groups_siui(id_lab_tests_siui,
>> id_lab_tests_groups, valid_from);" index works fine.
>>
>> I tested this on postgres 9.1.4 and 9.1.9.
>
> This is normal operation, as one NULL is unique from other NULLS, as
> far as the db is concerned. If you want it to work some other way, you
> need to use a value other than null, or make an index that's something
> like un

dangit, stupid gmail sent early.  anyway.

you'd have to make an index like unique index on (x,y,z) where field
is [not] null or something like that.

Basically NULL <> NULL <> a particular value.


pgsql-general by date:

Previous
From: Scott Marlowe
Date:
Subject: Re: Unique index problem
Next
From: Andreas Kretschmer
Date:
Subject: Re: Unique index problem