Как исправить уникальный ключ, чтобы не разрешать дубликаты записей
-
19-09-2019 - |
Вопрос
Вот моя проблема: ключ "IDX_SR_U_IDENITY_FINGERPRINTPROFILE" предназначен для ограничения полей "C_R_FINGERPRINT" и "C_R_PROFILE", чтобы быть уникальным.
Кажется, что я сделал что -то не так, потому что все 4 записи в таблице имеют идентичные значения для этих двух полей. Это нормально, если две записи имеют одинаковый отпечаток пальца или один и тот же профиль, но не обе.
Как я могу правильно указать этот уникальный ключ, чтобы такие дубликаты не допускаются?
(источник: Rigel222.com)
Решение
Я думаю, что ваш ключ верен, но MySQL не применяет его к NULL
ценности. А MySQL Docs для создания таблицы государство:
Уникальный индекс позволяет несколько нулевых значений для столбцов, которые могут содержать нуль.
В то время как записи, такие как (1,2), могут происходить только один раз, записи, такие как (1, нулевой), могут происходить несколько раз, они не считаются дубликатами из -за NULL
.
В зависимости от вашего варианта использования, вы можете запретить NULL
Чтобы два столбца обошли проблему.