Du kan inte lätt göra detta. least()
/greatest()
tillvägagångssätt kommer inte att fungera i alla fall.
Postgres har några snygga indexoperationer. Men det bästa sättet är att använda en korsningstabell. Till exempel:
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)
);
Detta begränsar också antalet telefonnummer till 2 för varje användare.