Основы современных баз данных



Получение реляционной схемы из ER-схемы - часть 2


Все в одной таблицеТаблица - на подтип

Преимущества

Все хранится вместе
Легкий доступ к супертипу и подтипам
Требуется меньше таблиц
Более ясны правила подтипов
Программы работают только с нужными таблицами

Недостатки

Слишком общее решение
Требуется дополнительная логика работы с разными наборами столбцов и разными ограничениями
Потенциальное узкое место (в связи с блокировками)
Столбцы подтипов должны быть необязательными
В некоторых СУБД для хранения неопределенных значений требуется дополнительная память
Слишком много таблиц
Смущающие столбцы в представлении UNION
Потенциальная потеря производительности при работе через UNION
Над супертипом невозможны модификации

Шаг 7. Имеется два способа работы при наличии исключающих связей:

  • общий домен (а)

  • явные внешние ключи (б)

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

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

    Общий доменЯвные внешние ключи

    Преимущества

    Нужно только два столбцаУсловия соединения - явные

    Недостатки

    Оба дополнительных атрибута должны использоваться в соединенияхСлишком много столбцов

    Альтернативные модели сущностей:

    Вариант 1 (плохой)

    Вариант 2 (существенно лучше, если подтипы действительно существуют)

    Вариант 3 (годится при наличии осмысленного супертипа D).




    Содержание  Назад  Вперед