Ошибка уникального индекса

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

Проверьте индекс, вставив запись с повторяющимся идентификатором сотрудника.

CREATE INDEX empid_index ON staff (empId)

Ожидал сообщение об ошибке о дублирующемся ID, но ошибки не вышло, запись все равно сохранилась.

Вы не создали уникальный индекс с этим предложением. Для этого вам нужно сделать СОЗДАТЬ УНИКАЛЬНЫЙ ИНДЕКС empid_index НА персонал (empId)

nacho 28.05.2019 20:32

Спасибо за вашу помощь, ценю это.

Jdeleon 28.05.2019 21:24

Почему это не PRIMARY KEY??

Rick James 29.05.2019 07:45
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
2
3
78
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Не создавайте уникальные индексы: вместо этого добавьте в таблицу уникальные ограничения. Например:

create table staff (
  ...
  constraint unique_empid unique (empid),
  ...
);

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

Другие вопросы по теме