Du kan ikke nemt gøre dette. least()
/greatest()
tilgang vil ikke fungere i alle tilfælde.
Postgres har nogle smarte indeksoperationer. Men den bedste måde er at bruge et krydstabel. For eksempel:
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)
);
Dette begrænser også antallet af telefonnumre til 2 for hver bruger.