sql >> Databasteknik >  >> RDS >> PostgreSQL

Unik värdebegränsning över flera kolumner

Du kan inte lätt göra detta. least() /greatest() tillvägagångssätt kommer inte att fungera i alla fall.

Postgres har några snygga indexoperationer. Men det bästa sättet är att använda en korsningstabell. Till exempel:

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)
);

Detta begränsar också antalet telefonnummer till 2 för varje användare.



  1. Optimera MySQL-frågor med många LEFT JOINs och GROUP BY

  2. Butikslösenord är ok i php Sessionsvariabel?

  3. SQL-fel ORA-01722:ogiltigt nummer

  4. Använda Dapper med SQL Spatial Types som parameter