PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Eindeutige Wertbeschränkung über mehrere Spalten hinweg

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.