Мегаобучалка Главная | О нас | Обратная связь


Ссылочная целостность данных



2020-03-17 344 Обсуждений (0)
Ссылочная целостность данных 0.00 из 5.00 0 оценок




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

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

В практике реализации ссылочной целостности наиболее широко используются две стратегии : стратегия ограничения (запрета) и стратегия каскадирования, значительно реже - стратегия установки значений по умолчанию, стратегия игнорирования и стратегия установки неопределенного значения (в NULL).

Суть стратегии ограничения заключается в том, что накладывается запрет на транзакции, выполнение которых может повлечь за собой нарушение ссылочной целостности. Следует заметить, что данная стратегия является достаточно простой с точки зрения ее реализации. В рамках ее выполнения предстоит лишь проверить наличие в дочернем отношении кортежей, связанных с активным кортежем в родительском отношении. Под активным картежом будем понимать такой картеж, над которым выполняется транзакция. При выполнении такой транзакции, как удаление кортежа в основном отношении, сохранится ссылочная целостность, если будет реализовано следующее ограничение целостности: “При попытке удаления кортежа в реляционном отношении “Мастер” реализовывать стратегию ограничения (запрета на удаление), при условии, что в порожденном отношении “Услуга” существуют кортежи, непосредственно связанные с удаляемым”. Таким образом, при реализации данной стратегии выполнение операции удаления кортежа из основного отношения будет возможным, если в порожденном отношении не найдется кортежа, непосредственно связанного с удаляемым (для данного случая - если отсутствуют данные об услугах данного мастера). Заметим, в данном случае недопустимо использование стратегии ограничения для операции удаления кортежа в порожденном отношении. Наиболее приемлемой здесь будет стратегия игнорирования либо стратегия каскадирования.

Суть стратегии каскадирования заключается в том, что допускается выполнение необходимой транзакции и при этом вносятся соответствующие изменения в тех отношениях, которые связаны с текущем (с тем, в который в данный момент производится транзакция). Изменения в отношениях, связанных с текущем реализуются с целью не допустить нарушения ссылочной целостности и сохранить при этом все имеющиеся связи. Чаще всего изменение начинается в родительском отношении и каскадно выполняется в порожденном отношении. Следует заметить, что последнее может в свою очередь выступать в качестве материнского для каких-либо других отношений. В связи с этим может возникнуть необходимость соответствующих изменениях (транзакциях) и в этих отношениях. Если при этом какая-либо из каскадных операций (любого уровня) не может быть выполнена, то необходимо отказаться от первоначальной операции и вернуть базу данных в исходное состояние. Это самая сложная стратегия, но она хороша тем, что при этом не нарушается связь между кортежами родительского и дочернего отношений.

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

Как было отмечено ранее, в некоторых случаях для поддержания ссылочной целостности используется стратегия установки по умолчанию. В рамках данной стратегии разрешается выполнение требуемой операции, но все возникающие некорректные значения внешних ключей при этом изменяются на некоторое значение, которое принятое по умолчанию. Достоинство этой стратегии по сравнению с предыдущей в том, что она позволяет не пользоваться null-значеними. Недостатки заключаются в следующем. Во-первых, в родительском отношении должен быть некий кортеж, потенциальный ключ которого принят как значение по умолчанию для внешних ключей. В качестве такого "кортежа по умолчанию" обычно принимают специальный кортеж, заполненный нулевыми значениями (не null-значениями!). Этот кортеж нельзя удалять из родительского отношения, и в этом кортеже нельзя изменять значение потенциального ключа. Таким образом, не все кортежи родительского отношения становятся равнозначными, поэтому приходится прилагать дополнительные усилия для отслеживания этой неравнозначности. Это плата за отказ от использования null-значений. Во-вторых, как и в предыдущем случае, кортежи дочернего отношения теряют всякую связь с кортежами родительского отношения. Установить, с каким кортежем родительского отношения были связаны измененные кортежи дочернего отношения, после выполнения операции уже нельзя.

И, наконец, стратегия ингнорирования (IGNORE), суть которой заключается в том, что разрешено выполнять любые транзакции, не обращая при этом внимание на нарушения ссылочной целостности.

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

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

Определив виды семантической и ссылочной целостности, перейдем к рассмотрению организации ограничений целостности средствами СУБД MySQL на примере фрагмента информационной системы «Салон магии».


 

Глава II. Реализация ограничений семантической и ссылочной целостности в СУБД MySQL на примере фрагмента ИС “Салон магии”

В данной главе рассмотрим реализацию запросов инструментальными средствами СУБД MySQL. В качестве примера возьмем фрагмент информационной системы «Салон магии». Данная предметная область является вполне подходящей для демонстрации различных видов запросов



2020-03-17 344 Обсуждений (0)
Ссылочная целостность данных 0.00 из 5.00 0 оценок









Обсуждение в статье: Ссылочная целостность данных

Обсуждений еще не было, будьте первым... ↓↓↓

Отправить сообщение

Популярное:
Организация как механизм и форма жизни коллектива: Организация не сможет достичь поставленных целей без соответствующей внутренней...
Почему человек чувствует себя несчастным?: Для начала определим, что такое несчастье. Несчастьем мы будем считать психологическое состояние...
Как построить свою речь (словесное оформление): При подготовке публичного выступления перед оратором возникает вопрос, как лучше словесно оформить свою...



©2015-2024 megaobuchalka.ru Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. (344)

Почему 1285321 студент выбрали МегаОбучалку...

Система поиска информации

Мобильная версия сайта

Удобная навигация

Нет шокирующей рекламы



(0.008 сек.)