Реляционные базы данных-правила формирования отношений

Автор работы: Пользователь скрыл имя, 12 Декабря 2011 в 12:03, курсовая работа

Краткое описание

Задачами данной работы являются:
- дать основные понятия баз данных, описать
архитектуру СУБД, модели данных;
- раскрыть модель сущность-связь, описать
характеристику связей, классификацию сущностей, структуру первичных и внешних
ключей, определить понятие целостности данных;
- описать реляционную структуру данных, реляционные
базы данных и способы манипулирования ими.

Содержание работы

Введение

Глава 1. Основные понятия БД и СУБД
...............5

1.1 Данные и
ЭВМ..........................5

1.2 Архитектура
СУБД......................7

1.3 Модели
данных......................10
Глава 2. Инфологическая модель данных
"Сущность-связь".....12
2.1 Основные
понятия.......................12

2.2 Характеристика связей и язык
моделирования.........14

2.3 Классификация
сущностей..................16

2.4 Первичные и внешние
ключи.................19

2.5 Ограничения
целостности....................23

Глава 3. Реляционный
подход..................25

3.1 Реляционная структура
данных.................25

3.2 Реляционная база
данных.....................28

3.3 Манипулирование реляционными
данными...........30

Заключение

Список используемой
литературы

Содержимое работы - 1 файл

Курсовая.docx

— 40.61 Кб (Скачать файл)

УСТАНАВЛИВАЕТСЯ  Для всех поставок удаляемого поставщика NULL-значение внешний ключ устанавливается в неопределенное значение, а затем этот поставщик удаляется. Такая возможность, конечно, неприменима, если данный внешний ключ не должен содержать NULL-значений.  
 

3. Что  должно происходить при попытке  ОБНОВЛЕНИЯ первичного ключа  целевой

сущности, на которую ссылается некоторый  внешний ключ? Например, может быть

предпринята попытка обновить номер такого поставщика, для которого имеется по

крайней мере одна соответствующая поставка. Этот случай для определенности

снова рассмотрим подробнее. Имеются те же три возможности, как и при

удалении:

     КАСКАДИРУЕТСЯ  Операция обновления "каскадируется" с тем, чтобы обновить также и внешний ключ впоставках этого поставщика.

ОГРАНИЧИВАЕТСЯ  Обновляются первичные ключи лишь тех поставщиков, которые еще не осуществляли поставок. Иначе операция обновления отвергается.

УСТАНАВЛИВАЕТСЯ  Для всех поставок такого поставщика NULL-значение внешний ключ устанавливается в неопределенное значение, а затем обновляется первичный ключ поставщика. Такая возможность, конечно, неприменима, если данный внешний ключ не должен содержать NULL-значений.  
 

Таким образом, для каждого внешнего ключа  в проекте проектировщик базы данных

должен  специфицировать не только поле или  комбинацию полей, составляющих этот

внешний ключ, и целевую таблицу, которая  идентифицируется этим ключом, но

также и ответы на указанные выше вопроса (три ограничения, которые относятся

к этому  внешнему ключу).

Наконец, о характеристиках – обозначающих сущностях, существование которых

зависит от типа обозначаемых сущностей. Обозначение  представляется внешним

ключом  в таблице, соответствующей этой характеристике. Но три рассмотренные

выше  ограничения на внешний ключ для  данного случая должны специфицироваться

следующим образом:

NULL-значения  не допустимы

УДАЛЕНИЕ  ИЗ (цель) КАСКАДИРУЕТСЯ

ОБНОВЛЕНИЕ (первичный ключ цели) КАСКАДИРУЕТСЯ

Указанные спецификации представляют зависимость  по существованию

характеристических  сущностей.

    

     

2.5       Ограничения целостности 

     Целостность (от англ. integrity – нетронутость, неприкосновенность,

сохранность, целостность) – понимается как правильность данных в любой момент

времени. Но эта цель может быть достигнута лишь в определенных пределах: СУБД

не может  контролировать правильность каждого  отдельного значения, вводимого в

базу  данных (хотя каждое значение можно  проверить на правдоподобность).

Например, нельзя обнаружить, что вводимое значение 5 (представляющее номер дня

недели) в действительности должно быть равно 3. С другой стороны, значение 9

явно  будет ошибочным и СУБД должна его отвергнуть. Однако для этого  ей следует

сообщить, что номера дней недели должны принадлежать набору (1,2,3,4,5,6,7).

Поддержание целостности базы данных может рассматриваться  как защита данных

от неверных изменений или разрушений (не путать с незаконными изменениями и

разрушениями, являющимися проблемой безопасности). Современные СУБД имеют ряд

средств для обеспечения поддержания  целостности (так же, как и средств

обеспечения поддержания безопасности).

Выделяют  три группы правил целостности:

1.                      Целостность по сущностям.

2.                      Целостность по ссылкам.

3.                      Целостность, определяемая пользователем.

В п. 2.3 была рассмотрена мотивировка двух правил целостности, общих для

любых реляционных баз данных.

1.          Не допускается, чтобы какой-либо  атрибут, участвующий в первичном

ключе, принимал неопределенное значение.

2.          Значение внешнего ключа должно  либо:

- быть  равным значению первичного ключа  цели;

- быть  полностью неопределенным, т.е. каждое  значение атрибута, участвующего

во внешнем  ключе должно быть неопределенным.

Для любой  конкретной базы данных существует ряд  дополнительных специфических

правил, которые относятся к ней одной  и определяются разработчиком.

    

     

Глава 3. Реляционный подход.

 

3.1              Реляционная структура данных 

В конце 60-х годов появились работы, в  которых обсуждались возможности

применения  различных табличных даталогических моделей данных, т.е.

возможности использования привычных и естественных способов представления

данных. Наиболее значительной из них была статья сотрудника фирмы IBM д-ра

Э.Кодда (Codd E.F., A Relational Model of Data for Large Shared Data Banks.

CACM 13: 6, June 1970), где, вероятно, впервые был применен термин

"реляционная  модель данных".

Будучи  математиком по образованию Э.Кодд предложил использовать для обработки

данных  аппарат теории множеств (объединение, пересечение, разность, декартово

произведение). Он показал, что любое представление  данных сводится к

совокупности  двумерных таблиц особого вида, известного в математике как 

отношение – relation (англ.).

Наименьшая  единица данных реляционной модели – это отдельное атомарное 

(неразложимое) для данной модели значение  данных. Так, в одной предметной

области фамилия, имя и отчество могут  рассматриваться как единое значение, а в

другой – как три различных значения.

     Доменом называется множество  атомарных значений одного и  того же типа.

Смысл доменов состоит в следующем. Если значения двух атрибутов берутся  из

одного  и того же домена, то, вероятно, имеют  смысл сравнения, использующие эти

два атрибута (например, для организации транзитного  рейса можно дать запрос

"Выдать  рейсы, в которых время вылета  из Москвы в Сочи больше  времени прибытия

из Архангельска в Москву"). Если же значения двух атрибутов берутся из

различных доменов, то их сравнение, вероятно, лишено смысла: стоит ли

сравнивать  номер рейса со стоимостью билета? Отношение на доменах D1, D2, ...,

Dn (не обязательно, чтобы все они были различны) состоит из заголовка и тела.

На рис. 3 приведен пример отношения для  расписания движения самолетов.

     Заголовок состоит из такого  фиксированного множества атрибутов  A1, A2,

..., An, что существует взаимно однозначное соответствие между этими атрибутами

Ai и определяющими их доменами Di (i=1,2,...,n).

                             

     Рисунок 3. Отношение с математической точки зрения (Ai - атрибуты, Vi -

значения  атрибутов)

     Тело состоит из меняющегося  во времени множества кортежей, где

каждый  кортеж состоит в свою очередь  из множества пар атрибут-значение (Ai:Vi),

(i=1,2,...,n), по одной такой паре для каждого атрибута Ai в заголовке. Для

любой заданной пары атрибут-значение (Ai:Vi) Vi является значением из

единственного домена Di, который связан с атрибутом Ai.

     Степень отношения – это число  его атрибутов. Отношение степени  один

называют  унарным, степени два – бинарным, степени три – тернарным, ..., а

степени n – n-арным.

     Кардинальное число или мощность  отношения – это число его

кортежей. Кардинальное число отношения изменяется во времени в отличие от его

степени.

Поскольку отношение – это множество, а  множества по определению не содержат

совпадающих элементов, то никакие два кортежа  отношения не могут быть

дубликатами друг друга в любой произвольно-заданный момент времени. Пусть R –

отношение с атрибутами A1, A2, ..., An. Говорят, что множество атрибутов

K=(Ai, Aj, ..., Ak) отношения R является возможным ключом R тогда и только

тогда, когда удовлетворяются два независимых  от времени условия:

1.     Уникальность: в произвольный заданный  момент времени никакие два

различных кортежа R не имеют одного и того же значения для Ai, Aj, ..., Ak.

2.     Минимальность: ни один из атрибутов  Ai, Aj, ..., Ak не может быть

исключен из K без нарушения уникальности.

Каждое  отношение обладает хотя бы одним  возможным ключом, поскольку по

меньшей мере комбинация всех его атрибутов  удовлетворяет условию

уникальности. Один из возможных ключей (выбранный  произвольным образом)

принимается за его первичный ключ. Остальные  возможные ключи, если они есть,

называются  альтернативными ключами.

Вышеупомянутые  и некоторые другие математические понятия явились

теоретической базой для создания реляционных  СУБД, разработки соответствующих

языковых  средств и программных систем, обеспечивающих их высокую

производительность, и создания основ теории проектирования баз данных. Однако

для массового  пользователя реляционных СУБД можно  с успехом использовать

неформальные  эквиваленты этих понятий:

Отношение – Таблица (иногда Файл),

Кортеж  – Строка (иногда Запись),

Атрибут – Столбец, Поле.

                       3.2  Реляционная база данных                      

Информация о работе Реляционные базы данных-правила формирования отношений