Отношение находится в 1 НФ форме т.и т.т.,



Когда на пересечении каждого столбца и каждой строки

Находятся только элементарные значения атрибутов.

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

Преподаватель День недели Номер пары Название дисциплины Тип занятий Группа

Петров В. И.

Понед. 1 Теор. выч. проц. Лекция 4906
Вторник 1 Комп. графика Лаб. раб.. 4907
Вторник 2 Комп. графика Лаб. раб 4906

Киров В. А.

Понед. 2 Теор. информ. Лекция 4906
Вторник 3 Пр-е на С++ Лаб. раб. 4907
Вторник 4 Пр-е на С++ Лаб. раб. 4906

Серов А. А.

Понед. 3 Защита инф. Лекция. 4944
Среда 3 Пр-е на VB Лаб. раб 4942
Четверг 4 Пр-е на VB Лаб. раб. 4922

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

Для приведения отношения "Расписание" к первой нормальной форме необходимо дополнить каждую строку фамилией преподавателя.

ОПРЕДЕЛЕНИЕ

Отношение находитсяв 2 НФ т.и т.т., когда оно находится в 1 НФ

И не содержит неполных функциональных зависимостей

Непервичных атрибутов от атрибутов первичного ключа.

 

Преподаватель День недели Номер пары Название дисциплины Тип занятий Группа
Петров В. И. Понед. 1 Теор. выч. проц. Лекция 4906
Петров В. И. Вторник 1 Комп. графика Лаб. раб.. 4907
Петров В. И. Вторник 2 Комп. графика Лаб. раб 4906
Киров В. А. Понед. 2 Теор. информ. Лекция 4906
Киров В. А. Вторник 3 Пр-е на С++ Лаб. раб. 4907
Киров В. А. Вторник 4 Пр-е на С++ Лаб. раб. 4906
Серов А. А. Понед. 3 Защита инф. Лекция. 4944
Серов А. А. Среда 3 Пр-е на VB Лаб. раб 4942
Серов А. А. Четверг 4 Пр-е на VB Лаб. раб. 4922

 

Рассмотрим отношение, моделирующее сдачу студентами текущей сессии. Структура этого отношения определяется следующим набором атрибутов:

(ФИО, Номер зач.кн., Группа, Дисциплина, Оценка)

Так как каждый студент сдает целый набор дисциплин в процессе сессии, то первичным ключом отношения может быть (Номер. зач.кн., Дисциплина), который однозначно определяет каждую стоку отношения. С другой стороны, атрибуты ФИО и Группа зависят только от части первичного ключа — от значения атрибута Номер зач. кн., поэтому мы должны констатировать наличие неполных функциональных зависимостей в данном отношении. Для приведения данного отношения ко второй нормальной форме следует разбить его на проекции, при этом должно быть соблюдено условие восстановления исходного отношения без потерь. Такими проекциями могут быть два отношения:

(ФИО, Номер.зач.кн., Группа) (Номер зач.кн., Дисциплина, Оценка)

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

А почему надо приводить отношения ко второй нормальной форме? Иначе говоря, какие аномалии или неудобства могут возникнуть, если мы оставим исходное отношение и не будем его разбивать на два? Давайте рассмотрим ситуацию, когда студент переведен из одной группы в другую. Тогда в первом случае (если мы не разбивали исходное отношение на два) мы должны найти все записи с данным студентом и в них изменить значение атрибута Группа на новое. Во втором же случае меняется только один кортеж в первом отношении. И конечно, опасность нарушения корректности (непротиворечивости содержания) БД в первом случае выше. Может получиться так, что часть кортежей поменяет значения атрибута Группа, а часть по причине сбоя в работе аппаратуры останется в старом состоянии. И тогда наша БД будет содержать записи, которые относят одного студента одновременно к разным группам. Чтобы этого не произошло, мы должны принимать дополнительные непростые меры, например организовывать процесс согласованного изменения с использованием сложного механизма транзакций, который мы будем рассматривать в лекциях, посвященных вопросам распределенного доступа к БД. Если же мы перешли ко второй нормальной форме, то мы меняем только один кортеж. Кроме того, если у нас есть студенты, которые еще не сдавали экзамены, то в исходном отношении мы вообще не можем хранить о них информацию, а во второй схеме информация о студентах и их принадлежности к конкретной группе хранится отдельно от информации, которая связана со сдачей экзаменов, и поэтому мы можем в этом случае отдельно работать со студентами и отдельно хранить и обрабатывать информацию об успеваемости и сдаче экзаменов, что в действительности и происходит.

ОПРЕДЕЛЕНИЕ

 


Дата добавления: 2018-04-15; просмотров: 368; Мы поможем в написании вашей работы!

Поделиться с друзьями:






Мы поможем в написании ваших работ!