Целостность реляционных данных - Операции, могущие нарушить ссылочную целостность

ОГЛАВЛЕНИЕ

Операции, могущие нарушить ссылочную целостность

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

Для родительского отношения

  • Вставка кортежа в родительском отношении
    При вставке кортежа в родительское отношение возникает новое значение потенциального ключа. Т.к. допустимо существование кортежей в родительском отношении, на которые нет ссылок из дочернего отношения, то вставка кортежей в родительское отношение не нарушает ссылочной целостности .
  • Обновление кортежа в родительском отношении
    При обновлении кортежа в родительском отношении может измениться значение потенциального ключа. Если есть кортежи в дочернем отношении, ссылающиеся на обновляемый кортеж, то значения их внешних ключей станут некорректными. Обновление кортежа в родительском отношении может привести к нарушению ссылочной целостности, если это обновление затрагивает значение потенциального ключа.
  • Удаление кортежа в родительском отношении
    При удалении кортежа в родительском отношении удаляется значение потенциального ключа. Если есть кортежи в дочернем отношении, ссылающиеся на удаляемый кортеж, то значения их внешних ключей станут некорректными. Удаление кортежей в родительском отношении может привести к нарушению ссылочной целостности.

Для дочернего отношения

  • Вставка кортежа в дочернее отношение
    Нельзя вставить кортеж в дочернее отношение, если вставляемое значение внешнего ключа некорректно. Вставка кортежа в дочернее отношение привести к нарушению ссылочной целостности .
  • Обновление кортежа в дочернем отношении
    При обновлении кортежа в дочернем отношении можно попытаться некорректно изменить значение внешнего ключа. Обновление кортежа в дочернем отношении может привести к нарушению ссылочной целостности .
  • Удаление кортежа в дочернем отношении
    При удалении кортежа в дочернем отношении ссылочная целостность не нарушается .

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

  • Обновление кортежа в родительском отношении.
  • Удаление кортежа в родительском отношении.
  • Вставка кортежа в дочернее отношение.
  • Обновление кортежа в дочернем отношении.