Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
BD_KL_2010_14.doc
Скачиваний:
0
Добавлен:
01.05.2025
Размер:
28.97 Mб
Скачать

2.3.2.Изменения, способные нарушить ссылочную целостность

Существует четыре типа изменений в базах данных, которые могут изменить ссылочную целостность отношений «предок – потомок»:

  • Добавление новой строки потомка. Когда происходит добавление новой строки в таблицу-потомок SLUZHASCHIE, значение ее внешнего ключа «ID_OFC» должно быть равно одному из значений первичного ключа «ID_OFC» в таблице-предке OFFISY. Если значение внешнего ключа не равно ни одному из значений первичного ключа, то добавление такой строки разрушит базу данных, поскольку появится потомок без предка («сирота»);

  • Обновление внешнего ключа в строке-потомке. Это та же проблема, что и в предыдущей ситуации, но выраженная в иной форме. Если внешний ключ «ID_OFC» обновляется инструкцией UPDATE, то его новое значение должно быть равно одному из значений первичного ключа «ID_OFC» в таблице-предке OFFISY. В противном случае обновленная строка окажется сиротой;

  • Удаление строки-предка. Если из таблицы-предка OFFISY будет удалена строка, у которой есть хотя бы один потомок (в таблице SLUZHASCHIE), то строки-потомки останутся сиротами. Значения внешних ключей «ID_OFC» в этих строках не будут равны ни одному из значений первичного ключа таблицы-предка OFFISY;

  • Обновление внешнего ключа в строке-предке. Если в таблице-предке OFFISY будет обновлено значение внешнего ключа для отдела, у которого есть хотя бы один потомок (в таблице SLUZHASCHIE), то строки-потомки останутся сиротами.

2.3.3.Правила ссылочной целостности

Для решения перечисленных проблем, возникающих при вставке, обновлении и удалении строк связанных таблиц, предусмотрены правила ссылочной целостности (referential integ­rity, RI). Правила ссылочной целостности – это логические конструкции, которые выражают бизнес-правила использования данных и представляют собой правила вставки, замены и удаления. При генерации схемы базы данных эти логические конструкции будут реализованы в виде правил декларативной ссылочной целостности, которые должны быть предписаны для каждой связи, и триггеры, обеспечивающие ссылочную целостность. Триггеры представляют собой программы, выполняемые всякий раз при выполнении команд вставки, замены или удаления (INSERT, UPDATE или DELETE).

Правило RESTRICT:

  • запрещает удаление строки из таблицы-предка, если строка имеет потомков. Инструкция DELETE, пытающаяся удалить такую строку, отбрасывается, и выдается сообщение об ошибке;

  • запрещает обновление первичного ключа в строке таблицы-предка, если у строки есть потомки. Инструкция UPDATE, пытающаяся изменить значение первичного ключа в строке-предке, отбрасывается, и выдается сообщение об ошибке;

Правило CASCADE:

  • определяет, что при удалении строки-предка все строки-потомки также автоматически удаляются из таблицы-потомка;

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

Правило SET NULL:

  • определяет, что при удалении строки-предка внешним ключам во всех ее строках-потомках автоматически присваивается значение NULL;

  • определяет, что при обновлении значения первичного ключа в строке-предке внешним ключам во всех ее строках-потомках автоматически присваивается значение NULL.

Правило SET DEFAULT:

  • определяет, что при удалении строки-предка внешним ключам во всех ее строках-потомках автоматически присваивается определенное значение, по умолчанию установленное для данного столбца;

  • определяет, что при обновлении значения первичного ключа в строке-предке внешним ключам во всех ее строках-потомках автоматически присваивается определенное значение, по умолчанию установленное для данного столбца.

Правило NONE:

  • определяет, что при удалении строки-предка значения внешних ключей во всех ее строках-потомках не меняются;

  • определяет, что при обновлении значения первичного ключа в строке-предке значения внешних ключей во всех ее строках-потомках не меняются.

Обычно правило NONE используется в «плоских» таблицах, так как в настольных или файл-серверных системах функциональность, обеспечивающая правила ссылочной целостности, реализуется в клиентском приложении.

Рассмотрим применение правил ссылочной целостности на примере одной из связей предок/потомок учебной базы данных. Относительно таблиц SLUZHASCHIE и OFFISY, связанных отношением предок-потомок, вышеописанные проблемы добавления, обновления и удаления с использованием перечисленных правил решаются следующим образом:

  1. Проблема, возникающая при добавлении новой строки потомка, решается путем проверки значений в столбцах внешнего ключа перед выполнением инструкции INSERT. Если они не равны ни одному из значений первичного ключа, то инструкция INSERT отбрасывается и выдается сообщение об ошибке. Другими словами применяется правило RESTRICT.

  2. Проблема, возникающая при обновлении внешнего ключа в строке-потомке, решается аналогично: путем проверки нового значения в столбцах внешнего ключа перед выполнением инструкции UPDATE. Если оно не равно ни одному из значений первичного ключа, то инструкция UPDATE отбрасывается и выдается сообщение об ошибке. То есть в данном случае также применяется правило RESTRICT.

  3. Проблема удаления строки-предка является более сложной. При этом в зависимости от ситуации можно:

  • Не удалять из базы данных отдел до тех пор, пока сотрудники не будут переведены в другой отдел. Другими словами применяется правило RESTRICT;

  • Автоматически удалить сотрудников, работавших в данном отделе, т. е. применить правило CASCADE;

  • в столбце «ID_OFC» установить для сотрудников, работавших в данном отделе, значение NULL, показывая, что номер их отдела пока не определен. Это означает применение правила SET NULL;

  • в столбце «ID_OFC» для сотрудников, работавших в данном отделе, установить значение по умолчанию некоторое значение, указывая, что сотрудники переводятся в этот отдел. Это означает применение правила SET DEFAULT.

  1. Проблема обновления внешнего ключа в строке-предке решается аналогично предыдущей:

  • не изменять «ID_OFC» до тех пор, пока сотрудники не будут переведены в другой отдел (правило RESTRICT);

  • автоматически обновить поле «ID_OFC» для сотрудников, работавших в данном отделе (правило CASCADE);

  • в столбце «ID_OFC» установить для сотрудников, работавших в данном отделе, значение NULL, показывая, что номер их отдела пока не определен (правило SET NULL);

  • в столбце «ID_OFC» для сотрудников, работавших в данном отделе, установить значение по умолчанию некоторое значение, указывая, что сотрудники переводятся в этот отдел (правила SET DEFAULT).

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]