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.