Как исправить уникальный ключ, чтобы не разрешать дубликаты записей

StackOverflow https://stackoverflow.com/questions/2422592

  •  19-09-2019
  •  | 
  •  

Вопрос

Вот моя проблема: ключ "IDX_SR_U_IDENITY_FINGERPRINTPROFILE" предназначен для ограничения полей "C_R_FINGERPRINT" и "C_R_PROFILE", чтобы быть уникальным.

Кажется, что я сделал что -то не так, потому что все 4 записи в таблице имеют идентичные значения для этих двух полей. Это нормально, если две записи имеют одинаковый отпечаток пальца или один и тот же профиль, но не обе.

Как я могу правильно указать этот уникальный ключ, чтобы такие дубликаты не допускаются?

alt text
(источник: Rigel222.com)

Это было полезно?

Решение

Я думаю, что ваш ключ верен, но MySQL не применяет его к NULL ценности. А MySQL Docs для создания таблицы государство:

Уникальный индекс позволяет несколько нулевых значений для столбцов, которые могут содержать нуль.

В то время как записи, такие как (1,2), могут происходить только один раз, записи, такие как (1, нулевой), могут происходить несколько раз, они не считаются дубликатами из -за NULL.

В зависимости от вашего варианта использования, вы можете запретить NULL Чтобы два столбца обошли проблему.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top