русс | укр

Языки программирования

ПаскальСиАссемблерJavaMatlabPhpHtmlJavaScriptCSSC#DelphiТурбо Пролог

Компьютерные сетиСистемное программное обеспечениеИнформационные технологииПрограммирование

Все о программировании


Linux Unix Алгоритмические языки Аналоговые и гибридные вычислительные устройства Архитектура микроконтроллеров Введение в разработку распределенных информационных систем Введение в численные методы Дискретная математика Информационное обслуживание пользователей Информация и моделирование в управлении производством Компьютерная графика Математическое и компьютерное моделирование Моделирование Нейрокомпьютеры Проектирование программ диагностики компьютерных систем и сетей Проектирование системных программ Системы счисления Теория статистики Теория оптимизации Уроки AutoCAD 3D Уроки базы данных Access Уроки Orcad Цифровые автоматы Шпаргалки по компьютеру Шпаргалки по программированию Экспертные системы Элементы теории информации

Связи более высокого порядка


Дата добавления: 2013-12-23; просмотров: 902; Нарушение авторских прав


Правило 6.

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

Пример проектирования с использованием связей степенью М:N

Проектируется БД, предназначенная для хранения информации о проводниках- рыболовах и об обслуживающих ими озерах. Профсоюз не возражает, чтобы сразу несколькими проводниками обслуживалось одно озеро. Туристы, нанимающие рыбаков, интересуются видами раб, которые водятся в озерах, самыми крупными экземплярами, пойманными за сезон в регионе и лучшей наживкой для каждого вида рыб в регионе.

 

Представляющими интерес атрибутами являются:

 

Фамилия проводника - П_фам

Номер телефона - Т_ном

Оплата задень - Оплата

Название озера - Н_озера

Максимальный размер группы - Размер

Рыболовная оценка озера - Оценка

Виды рыб - Вид

Вес самого большого экземпляра каждого вида - Вес

Лучшая наживка для каждого вида - Рыб_наж

 

Из предметной области выделяем:

Сущности - ПРОВОДНИК, ОЗЕРО, РЫБА

Связи - ОБСЛУЖИВАЕТСЯ, ВОДИТСЯ

 

 

По ER-диаграмме составляем отношения:

для правила (4) – Проводник (Пфам, …,Нозеро)

Озеро (Нозеро,…)

для правила (6 ) – Озеро (Нозеро,…)

Рыба (вид,…)

Водится (Нозеро, вид,…)

 

Далее составим отношения для всей схемы в общем:

Проводник (Пфам, Тном, оплата, размер, Нозеро)

Озеро (Нозеро, оценка)

Рыба (вид, вес, наживка)

Водится (Нозеро, вид)

 

Проверяем возможность ключей и детерминантов:



 

 

Если анализировать данные отношения, то обнаружим, что все находятся в НФБК, следовательно аномалий не будет.

 

Рассмотрим предыдущий пример. Предположим, что туристы, нанимающие проводника, хотят знать, какую рыбу предпочитает ловить проводник.

 

Связь между сущностями ПРОВОДНИК и РЫБА показали пунктиром.

 

Определяем отношения:

 

а) Проводник (Пфам,…,Нозеро)

Озеро (озеро,…)

б) Озеро (озеро,…)

Рыба (Вид,…)

Водится (озеро, вид,…)

в) Проводник (Пфам,…,вид)

Рыба (вид,…)

В данных отношениях есть повторяющиеся, вычеркиваем их (это Озеро,Рыба) и переписываем оставшиеся отношения для нашей БД:

Проводник (Пфам,…,озеро, вид)

Водится (озеро, вид,…)

Озеро (озеро,…)

Рыба (Вид,…)

 

Вывод : бинарных связей оказалось достаточно.

Усложним задачу. Предположим, что проводник может обслуживать несколько озер. При этом он может предпочитать ловить разную рыбу в разных озерах.

Например:

П1 обслуживает О1 и О2

П2 обслуживает О2

П1 предпочитает Р1 в О1

П1 предпочитает Р2 в О2

П2 предпочитает Р2 в О2

Составим ER- диаграмму

 

 

Изобразим ситуацию в виде диаграммы, в которой все связи бинарные:

 

Строим отношения:

 

Для а) Проводник (Пфам,…)

Озеро (озеро,…)

Обслуживает (Пфам, озеро)

Для б) Водится (озеро,…,вид)

Озеро (озеро,…)

Рыба (вид,…)

Для в) Проводник (Пфам,…)

Рыба (вид,…)

Предпочитает (Пфам, вид,…)

 

Вычеркиваем из полученных отношений повторяющиеся:

 

Проводник (Пфам,…)

Озеро (озеро)

Обслуживает (Пфам, озеро)

Водится (озеро,…,вид)

Рыба (вид,…)

Предпочитает (Пфам, вид,…) – некорректное отношение

 

Из полученных отношений можно заключить, что П1 обслуживает О1, в О1 водится Р2. П1 предпочитает ловить Р2. П1 предпочитает ловить в О1 Р2, что неверно. Следовательно, в данном случае только бинарными связями обойтись нельзя. Причина неудачи образования этой связи только с помощью бинарных связей заключается в следующем, что Пi проводник предпочитает ловить рыбу Рi в озере Оi т.е. здесь объединяются три сущности и такое высказывание нельзя заменить комбинациями из двух сущностей (т.е. заменить на бинарные связи).

Правильная модель должна использовать трехсторонний вид связи.

 

 

 

И в этой форме зарисовываем нашу предыдущую запись:

 

 

 

Рисуем ER–диаграмму:

 



<== предыдущая лекция | следующая лекция ==>
Правило 5. | Использование ролей


Карта сайта Карта сайта укр


Уроки php mysql Программирование

Онлайн система счисления Калькулятор онлайн обычный Инженерный калькулятор онлайн Замена русских букв на английские для вебмастеров Замена русских букв на английские

Аппаратное и программное обеспечение Графика и компьютерная сфера Интегрированная геоинформационная система Интернет Компьютер Комплектующие компьютера Лекции Методы и средства измерений неэлектрических величин Обслуживание компьютерных и периферийных устройств Операционные системы Параллельное программирование Проектирование электронных средств Периферийные устройства Полезные ресурсы для программистов Программы для программистов Статьи для программистов Cтруктура и организация данных


 


Не нашли то, что искали? Google вам в помощь!

 
 

© life-prog.ru При использовании материалов прямая ссылка на сайт обязательна.

Генерация страницы за: 0.004 сек.