Структура модели
Реляционная модель представляет собой многомерную таблицу элементов, строки которой называются кортежами. Сама таблица называется отношением. Поскольку одной таблицей не всегда удается описать сложные логические структуры, применяют связывание таблиц. Все строки таблицы отношений имеют одинаковую структуру и состоят из полей. Столбцы таблицы соответствуют атрибутам отношения. Элементы реляционной модели показаны в табл. 8.1.
Таблица 8.1. Элементы реляционной модели
Пример таблицы отношения СОТРУДНИК приведен на рис. 8.1. В общем случае порядок кортежей в отношении, как и в любом множестве, не определен. Для определенности в ряде случаев выбирают некоторый атрибут, по которому система автоматически сортирует кортежи по возрастанию или убыванию. Перестановка кортежей не приводит к образованию нового отношения.
Рис. 8.1. Таблица отношения СОТРУДНИК
В приведенном примере отношение включает 4 домена. Каждый домен образует значения одного типа данных. Ключом отношения (ключевым атрибутом) называется атрибут отношения, однозначно идентифицирующий каждый из его кортежей. Ключ может быть составным, т.е. состоять из нескольких атрибутов. Могут существовать несколько ключей отношения. Любой из них может быть выбран как первичный. Если ключ состоит из минимально необходимого набора атрибутов, он является не избыточным. Если в одном отношении есть атрибут, значение которого является значением ключевого атрибута другого отношения, указанный атрибут называется внешним ключом. С помощью внешних ключей устанавливаются связи между отношениями. Реляционная модель накладывает на внешние ключи ограничение для обеспечения целостности данных, называемое ссылочнойцелостностью. Это означает, что каждому значению внешнего ключа должны соответствовать строки в связываемых отношениях. Исходные и получаемые после связывания отношения должны удовлетворять следующим требованиям: 1) все строки таблицы должны быть уникальны; 2) имена столбцов должны быть различны; 3) значение столбца должно быть простым (одно значение); 4) все строки одной таблицы должны иметь одну структуру.
|