<На страницу назад | На страницу вперед >
Миграция ключей - это процесс копирования первичного ключа одной сущности в другую, связанную с ней сущность. Эта копия называется внешним ключом. Значение внешнего ключа в каждом экземпляре второй сущности совпадает со значением связанного экземпляра первой сущности. Таким образом атрибут, принадлежащий одной сущности, разделяется с другой сущностью. Миграция ключей подчиняется следующим трем правилам:
Каждый атрибут внешнего ключа соответствует атрибуту первичного ключа родительской или общей сущности. Первичный ключ сущности-категории в категориальном отношении должен совпадать с первичным ключом общей сущности. В других отношениях атрибут внешнего ключа может, но не обязан быть частью первичного ключа сущности-потомка. Атрибуты внешних ключей не считаются принадлежащими сущностям, в которых они появляются, поскольку они отражают атрибуты родительских сущностей. Таким образом, каждый атрибут в сущности либо принадлежит этой сущности, либо принадлежит внешнему ключу этой сущности.
В диаграммах модели внешние ключи обозначаются примерно так же, как альтернативные ключи, т.е. после каждого атрибута, принадлежащего внешнему ключу, следует (FK). Если атрибут принадлежит также первичному ключу, то он располагается выше горизонтальной линии, а если нет, то - ниже. Если первичный ключ сущности-потомка содержит все атрибуты внешнего ключа, то сущность-потомок называется зависимой от идентификатора относительно родительской сущности, а отношение называется идентифицирующим отношением. Если какие-либо атрибуты внешнего ключа не принадлежат первичному ключу сущности-потомка, то сущность-потомок не является независимой от идентификатора относительно родительской сущности, а отношение называется неидентифицирующим. На диаграммах стадий 3 и 4 сплошными линиями изображаются только идентифицирующие отношения, а неидентифицирующие отношения изображаются пунктирными линиями.
Сущность, являющаяся сущностью-потомком в одном или нескольких идентифицирующих отношениях, называется зависимой от идентификатора. Сущность, являющаяся сущностью-потомком только в неидентифицирующих отношениях (или не являющаяся сущностью-потомком ни в одном из отношений), называется независимой от идентификатора. В диаграммах стадий 3 и 4 блоками с прямыми углами изображаются только идентификаторно-независимые сущности, а идентификаторно-зависимые сущности изображаются блоками с закругленными углами. На рис. 4-13 приведен пример миграции ключа атрибута из родительской сущности к сущности-потомку.
Рис. 4-13. Миграция ключа к зависимой от идентификатора сущности
В этом примере атрибут НОМЕР_ПОКУПАТЕЛЯ (первичный ключ сущности ПОКУПАТЕЛЬ) мигрирует в сущность ЗАКАЗ (т.е. является внешним ключом в этой сущности). Этот атрибут затем используется в сущности ЗАКАЗ в качестве элемента его первичного ключа вместе с другим атрибутом, называющимся НОМЕР_ЗАКАЗА, принадлежащим ЗАКАЗУ. Эти два атрибута (НОМЕР_ПОКУПАТЕЛЯ и НОМЕР_ЗАКАЗА) вместе образуют первичный ключ сущности ЗАКАЗ.
На рис. 4-14 приведен пример миграции ключа атрибута из идентификаторно-независимой сущности к другой идентификаторно-независимой сущности. В этом примере атрибут НОМЕР_ОТДЕЛА мигрирует к сущности СЛУЖАЩИЙ. Однако первичным ключом сущности СЛУЖАЩИЙ является ИДЕНТИФИКАТОР_СЛУЖАЩЕГО. Поэтому НОМЕР_ОТДЕЛА появляется в качестве внешнего ключа ниже линии ключевых атрибутов. Линия отношения является пунктирной, поскольку это отношение - неидентифицирующее.
Рис. 4-14. Миграция ключей в независимую от идентификатора сущность
Один и тот же атрибут может порождать в одной и той же сущности-потомке более одного внешнего ключа. Так происходит при миграции атрибута в сущность-потомок более чем через одно отношение. В некоторых случаях каждый экземпляр сущности-потомка должен обладать в обоих внешних ключах одним и тем же значением для этого атрибута. Когда это так, атрибут появляется внутри сущности столько раз и идентифицируется в качестве внешнего ключа. В других случаях экземпляр сущности может (или должен) обладать различными значениями в каждом внешнем ключе. В этих случаях атрибут появляется внутри сущности более одного раза, что приводит к необходимости отличать одно появление от другого. Для этого каждому присваивается имя роли, показывающее, чем одно появление отличается от другого (рис. 4-15).
Рис. 4-15. Имена ролей атрибутов