Sie können dies nicht einfach tun. Das least()
/greatest()
Ansatz wird nicht in allen Fällen funktionieren.
Postgres hat einige ausgefallene Indexoperationen. Aber der beste Weg ist, eine Verbindungstabelle zu verwenden. Zum Beispiel:
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)
);
Dadurch wird auch die Anzahl der Telefonnummern für jeden Benutzer auf 2 begrenzt.