PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Ograniczenie unikatowej wartości w wielu kolumnach

Nie możesz tego łatwo zrobić. least() /greatest() podejście nie zadziała we wszystkich przypadkach.

Postgres ma kilka wymyślnych operacji indeksowania. Ale najlepszym sposobem jest użycie tabeli połączeń. Na przykład:

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

Ogranicza to również liczbę numerów telefonów do 2 dla każdego użytkownika.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PostgreSQL - GROUP BY wartości znacznika czasu?

  2. pg_upgrade w systemie Windows nie może zapisywać do pliku dziennika pg_upgrade_internal.log

  3. Atrybut numer 10 przekracza liczbę kolumn 0

  4. Rails 4:Użycie funkcji PostgreSQL w celu powoduje błąd w zapytaniu z powodu braku dołączenia tabeli include

  5. Jak określić listę wartości dla sekwencji postgresql?