Anda tidak dapat dengan mudah melakukan ini. least()
/greatest()
pendekatan tidak akan berhasil dalam semua kasus.
Postgres memang memiliki beberapa operasi indeks mewah. Tetapi cara terbaik adalah dengan menggunakan meja persimpangan. Misalnya:
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)
);
Ini juga membatasi jumlah nomor telepon menjadi 2 untuk setiap pengguna.