Русская Википедия:Вторая нормальная форма

Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску

Шаблон:Main Вторая нормальная форма (Шаблон:Lang-en; сокращённо 2NF) — одна из возможных нормальных форм отношения в реляционной базе данных.

Определение

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

Неприводимость означает, что в составе потенциального ключа отсутствует меньшее подмножество атрибутов, от которого можно также вывести данную функциональную зависимостьШаблон:Sfn. Для неприводимой функциональной зависимости часто используется эквивалентное понятие «полная функциональная зависимость»Шаблон:Sfn.

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

Пример

Пример приведения отношения ко второй нормальной форме

Пусть в следующем отношении первичный ключ образует пара атрибутов {Филиал компании, Должность}:

R
Филиал компании Должность Зарплата Наличие компьютера
Филиал в Томске Уборщик 20000 Нет
Филиал в Москве Программист 40000 Есть
Филиал в Томске Программист 25000 Есть

Допустим, что зарплата зависит от филиала и должности, а наличие компьютера зависит только от должности.

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

Для приведения к 2NF исходное отношение следует декомпозировать на два отношения:

R1
Филиал компании Должность Зарплата
Филиал в Томске Уборщик 20000
Филиал в Томске Программист 25000
Филиал в Москве Программист 40000
R2
Должность Наличие компьютера
Уборщик Нет
Программист Есть

Примечания

Шаблон:Примечания

Литература

На русском языке

Переводная

На английском языке

Шаблон:Нормальные формы Шаблон:Rq