PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Restrição de valor exclusivo em várias colunas


Você não pode fazer isso facilmente. O least() /greatest() abordagem não funcionará em todos os casos.

O Postgres tem algumas operações de índice sofisticadas. Mas a melhor maneira é usar uma tabela de junção. Por exemplo:
create table userPhones (
    userPhoneId bigint primary key ,
    userId bigint references users(id),
    phone_counter int check (phone_counter in (1, 2)),
    phone varchar,
    unique (userId, phone_counter),
    unique(phone)
);

Isso também limita o número de números de telefone a 2 para cada usuário.