4.1.Реляционная модель данных
Реляционная модель предложена сотрудником компании IBM Е.Ф.Коддом в 1970
г. (русский перевод
статьи, в которой она впервые описана опубликован в журнале
"СУБД"
N 1 за 1995 г.). В настоящее время эта модель является фактическим стандартом,
на который ориентируются практически все современные коммерческие СУБД.
4.1.1.Структура данных.
В реляционной модели достигается гораздо более высокий уровень абстракции
данных, чем в иерархической или сетевой. В упомянутой статье Е.Ф.Кодда
утверждается, что "реляционная модель предоставляет средства описания
данных на основе только их естественной структуры, т.е. без потребности
введения какой-либо дополнительной структуры для целей машинного представления".
Другими словами, представление данных не зависит от способа их физической
организации. Это обеспечивается за счет использования математической теории
отношений (само название "реляционная" происходит от английского relation
- "отношение").
Перейдем к рассмотрению структурной части реляционной модели данных.
Прежде всего необходимо дать несколько определений.
Определения:
-
Декартово произведение: Для заданных
конечных множеств (не
обязательно различных) декартовым произведением
называется множество произведений вида: ,
где
Пример: если
даны два множества A (a1,a2,a3) и B (b1,b2), их декартово произведение
будет иметь вид С=A*B (a1*b1, a2*b1, a3*b1, a1*b2, a2*b2, a3*b2)
-
Отношение: Отношением R,
определенным на множествах
называется подмножество декартова произведения .
При этом:
-
множества называются
доменами отношения
-
элементы декартова произведения
называются кортежами
-
число n определяет степень отношения ( n=1 - унарное,
n=2 - бинарное, ..., n-арное)
-
количество кортежей называется мощностью отношения
Пример: на множестве С из предыдущего примера
могут быть определены отношения R1 (a1*b1, a3*b2) или R2 (a1*b1, a2*b1,
a1*b2)
Отношения удобно представлять в виде таблиц. На рис. 4.1 представлена
таблица (отношение степени 5), содержащая некоторые сведения о работниках
гипотетического предприятия. Строки таблицы соответствуют кортежам. Каждая
строка фактически представляет собой описание одного объекта реального
мира (в данном случае работника), характеристики которого содержатся в
столбцах. Можно провести аналогию между элементами реляционной модели данных
и элементами модели "сущность-связь". Реляционные отношения соответствуют
наборам сущностей, а кортежи - сущностям. Поэтому, также как и в модели
"сущность-связь" столбцы в таблице, представляющей реляционное отношение,
называют атрибутами.
Рис.4.1 Основные компоненты реляционного отношения.
Каждый атрибут определен на домене, поэтому домен можно рассматривать
как множество допустимых значений данного атрибута.
Несколько атрибутов одного отношения и даже атрибуты разных отношений
могут быть определены на одном и том же домене. В примере, показанном на
рис.4.1 атрибуты "Оклад" и "Премия" определены на домене "Деньги". Поэтому,
понятие домена имеет семантическую нагрузку: данные можно считать сравнимыми
только тогда, когда они относятся к одному домену. Таким образом, в рассматриваемом
нами примере сравнение атрибутов "Табельный номер" и "Оклад" является семантически
некорректным, хотя они и содержат данные одного типа.
Именнованное множество пар "имя атрибута - имя домена" называется схемой
отношения. Мощность этого множества - называют степенью или
"арностью" отношения. Набор именованных схем отношений представляет
из себя схему базы данных.
Атрибут, значение которого однозначно идентифицирует кортежи, называется
ключевым (или просто ключом). В нашем случае ключом является
атрибут "Табельный номер", поскольку его значение уникально для каждого
работника предприятия. Если кортежи идентифицируются только сцеплением
значений нескольких атрибутов, то говорят, что отношение имеет составной
ключ.
Отношение может содержать несколько ключей. Всегда один из ключей объявляется
первичным, его значения не могут обновляться. Все остальные ключи
отношения называются возможными ключами.
В отличие от иерархической и сетевой моделей данных в реляционной отсутствует
понятие группового отношения. Для отражения ассоциаций между кортежами
разных отношений используется дублирование их ключей. Рассмотренный в параграфах
3.1 и 3.2 пример базы данных, содержащей
сведения о подразделениях предприятия и работающих в них сотрудниках, применительно
к реляционной модели будет иметь вид:
Рис.4.2. База данных о подразделениях и сотрудниках предприятия.
Например, связь между отношениями ОТДЕЛ и СОТРУДНИК создается путем
копирования первичного ключа "Номер_отдела" из первого отношения
во второе. Таким образом:
-
для того, чтобы получить список работников данного подразделения, необходимо
-
из таблицы ОТДЕЛ установить значение атрибута "Номер_отдела",
соответствующее данному "Наименованию_отдела"
-
выбрать из таблицы СОТРУДНИК все записи, значение атрибута "Номер_отдела"
которых равно полученному на предыдушем шаге.
-
для того, чтобы узнать в каком отделе работает сотрудник, нужно выполнить
обратную операцию:
-
определяем "Номер_отдела" из таблицы СОТРУДНИК
-
по полученному значению находим запись в таблице ОТДЕЛ.
Атрибуты, представляющие собой копии ключей других отношений, называются
внешними ключами.
4.1.2.Свойства отношений.
-
Отсутствие кортежей-дубликатов. Из этого свойства вытекает наличие у
каждого кортежа первичного ключа. Для каждого отношения, по крайней мере,
полный набор его атрибутов является первичным ключом. Однако, при определении
первичного ключа должно соблюдаться требование "минимальности", т.е. в
него не должны входить те атрибуты, которые можно отбросить без ущерба
для основного свойства первичного ключа - однозначно определять кортеж.
-
Отсутствие упорядоченности кортежей.
-
Отсутствие упордоченности атрибутов. Для ссылки на значение атрибута всегда
используется имя атрибута.
-
Атомарность значений атрибутов, т.е. среди значений домена не могут содержаться
множества значений (отношения).
Более подробно о фундаментальных свойствах отношений можно прочитать в
"Введении
в СУБД" С.Д.Кузнецова.
Следующая глава: 4.2.Теория нормальных форм
Введение в базы данных. (c) Зеленков
Ю.А. (yz@yars.free.net) 1997
г.
(c) Центр Интернет ЯрГУ