Не можете лесно да направите това. least()
/greatest()
подходът няма да работи във всички случаи.
Postgres има някои фантастични операции с индекси. Но най-добрият начин е да използвате съединителна маса. Например:
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)
);
Това също така ограничава броя на телефонните номера до 2 за всеки потребител.