Многие разработчики избегают ограничений внешнего ключа, так как эти ограничения делают неудобным обновление связанных столбцов во многих таблицах. Например, если необходимо удалить строку, от которой зависят другие строки, потребуется удалить сначала дочерние строки, чтобы избежать нарушения ограничений внешнего ключа:
Файл npm*epa:_Keyless-Entry/anti/delete-child.sql
DELETE FROM BugStatus WHERE status = 'BOGUS'; — ОШИБКА! DELETE FROM Bugs WHERE status = 'BOGUS';
DELETE FROM BugStatus WHERE status = 'BOGUS'; — успешная попытка
Необходимо написать множество операторов, по одному для каждой дочерней таблицы. Если добавить еще одну дочернюю таблицу в планируемое расширение базы данных, потребуется скорректировать программный код, чтобы выполнить удаление и из новой таблицы. Но эту проблему можно решить.
Неразрешимая проблема возникает, когда выполняется операция UPDATE для столбца, от которого зависят дочерние строки. Нельзя обновить дочерние строки до обновления родительского объекта, и невозможно обновить родительский объект до обновления значений дочерних элементов, которые ссылаются на него. Требуется выполнить оба изменения одновременно, но это невозможно сделать, используя два отдельных обновления. Это скрипт Уловки-22.
Файл r\pHHepa:_Keyless-Entry/anti/update-catch22.sqi
UPDATE BugStatus SET status = 'INVALID' WHERE status = 'BOGUS'; — ОШИБКА!
UPDATE Bugs SET status = 'INVALID' WHERE status = 'BOGUS'; --ОШИБКА!
Некоторые разработчики считают эти скрипты трудными для управления, поэтому они решают вообще не использовать внешние ключи. Ниже будет показано, как внешние ключи просто и эффективно справляются с многотабличными обновлениями и удалениями.
Опубликовал vovan666
June 18 2013 12:26:02 ·
0 Комментариев ·
3623 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.