Следующей нормальной формой, которую мы подвергнем
рассмотрению, является третья нормальная форма (или 3NF). В отличие от
первой нормальной формы, так же как и вторая нормальная форма, третья –
подразумевает задание вместе с отношением системы функциональных
зависимостей. Сформулируем, какими свойствами должно обладать отношение,
чтобы оно было приведенным к третьей нормальной форме.
Определение. Базовое отношение находится в третьей нормальной форме
относительно заданного множества функциональных зависимостей тогда и
только тогда, когда оно находится во второй нормальной форме и каждый
неключевой атрибут полностью функционально зависит только от ключей.
Таким образом, требования, предъявляемые третьей
нормальной формой, сильнее требований, накладываемых первой и второй
нормальной формой, даже вместе взятых. Фактически в третьей нормальной
форме каждый неключевой атрибут зависит от ключа, причем от всего ключа
целиком и ни от чего другого, кроме как от ключа.
Проиллюстрируем процесс приведения ненормализованного
отношения к третьей нормальной форме. Для этого рассмотрим пример:
отношение, находящееся не в третьей нормальной форме.
Итак, вариант 1 схемы отношения «Сотрудники»:
Сотрудники (№ табельный, Фамилия, Имя, Отчество, Код должности, Оклад);
Primary key (№ табельный);
Кроме того, над данным отношением «Сотрудники» задана следующая система функциональных зависимостей:
{Код должности} → {Оклад};
Действительно, как правило, от должности, а
следовательно, от ее кода в соответствующей базе данных напрямую
зависит размер оклада, т. е. размер заработной платы.
Именно поэтому это отношение «Сотрудники» и не находится
в третьей нормальной форме, ведь получается, что неключевой атрибут
«Оклад» полностью функционально зависит от атрибута «Код должности»,
хотя этот атрибут и не является ключевым.
Любопытно, что к третьей нормальной форме любое
отношение приводится точно таким же методом, как и к двум формам до
этой, а именно, путем декомпозиции.
Проведя декомпозицию отношения «Сотрудники», получим следующую систему новых самостоятельных отношений:
Итак, вариант 2 схемы отношения «Сотрудники»:
Должности (Код должности, Оклад);
Primary key (Код должности);
Сотрудники (№ табельный, Фамилия, Имя, Отчество, Код должности);
Primary key (Код должности);
Foreign key (Код должности) references Должности (Код должности);
Теперь, как мы видим, в отношении
«Должности» неключевой атрибут «Оклад» полностью функционально зависит
от простого первичного ключа «Код должности» и только от этого ключа.
Заметим, что в отношении «Сотрудники» все четыре
неключевых атрибута «Фамилия», «Имя», «Отчество» и «Код должности»
полностью функционально зависят от простого первичного ключа «№
табельный». В этом отношении атрибут «Код должности» – внешний ключ,
ссылающийся на первичный ключ отношения «Должности».
В данном примере все требования навязаны объявлением
простых первичных и внешних ключей, поэтому дальнейшая нормализация не
требуется.
Интересно и полезно знать, что на практике обычно
ограничиваются приведением баз данных к третьей нормальной форме. При
этом, возможно, не навязанными остаются некоторые функциональные
зависимости ключевых атрибуты от других атрибутов этого же отношения.
Поддержка таких нестандартных функциональных
зависимостей реализуется при помощи уже упоминаемых ранее триггеров (т.
е. процедурно, путем написания соответствующего программного кода).
Причем триггеры должны оперировать кортежами этого отношения. |