Tenho uma tabela assim:
create table my_table (
id int8 not null,
id_A int8 not null,
id_B int8 not null,
id_C int8 null,
constraint pk_my_table primary key (id),
constraint u_constrainte unique (id_A, id_B, id_C)
);
E eu quero (id_A, id_B, id_C)
ser distinto em qualquer situação. Portanto, as duas inserções a seguir devem resultar em um erro:
INSERT INTO my_table VALUES (1, 1, 2, NULL);
INSERT INTO my_table VALUES (2, 1, 2, NULL);
Mas não se comporta como esperado pois de acordo com a documentação, dois NULL
valores não são comparados entre si, então ambas as inserções passam sem erro.
Como posso garantir minha restrição exclusiva, mesmo que id_C
possa ser NULL
nesse caso? Na verdade, a verdadeira questão é: posso garantir esse tipo de exclusividade em "sql puro" ou tenho que implementá-lo em um nível superior (java no meu caso)?