Зведення про типи зв’язків наведені у додатку Б.
Тепер нам необхідно виділити атрибути сутностей, що у специфікаціях також можуть бути представлені іменниками (або відповідними сполученнями). Атрибут описує деякий аспект визначеної сутності або зв'язку. При виконанні цього етапу варто звернути особливу увагу на ті випадки, коли визначений атрибут справляє враження, ніби він описує більше одного типу сутності або зв'язку.
Зведення про виділені атрибути і їх приналежність відповідним сутностям та зв'язкам наведені в табл.1.2.
У документацію необхідно помістити докладні зведення про атрибути, перераховані у табл.1..2. Для кожного атрибута варто вказати загальний опис, тип даних і довжину значення, наявні обмеження, значення за замовчуванням (якщо таке є), псевдоніми (якщо такі існують), а також є атрибут складеним або
похідним і чи припустиме для нього значення NULL
. Фрагмент подібного документа наведений у кінці цього розділу (Додаток В).
На цьому етапі потрібно визначити домени атрибутів, поміщених у локальну концептуальну модель.
Доменом називають безліч припустимих значень для одного або більше атрибутів. Наприклад, домен атрибута Номер
сутності Відділення
складається з рядків довжиною до трьох символів, що мають значення від '111' до '999'.
Прикладом домену, поділюваного декількома атрибутами, є домен значень адрес. Атрибути Адреса
, що належать сутностям працівник,
мають той самий загальний домен припустимих значень. Зведення про домени атрибутів наведені у додатку Г.
Звернемося до табл. 1.2 і виділимо в ній усі можливі потенційні ключі для кожної із сутностей, представлених у локальній концептуальній моделі даних користувача Директор
. Потім зі знайдених потенційних ключів виберемо первинні ключі, що найбільше підходять для кожного типу сутності. Результати визначення первинних і альтернативних ключів для кожної із сутностей представлені в табл.1.3.
На цьому етапі приймаються (необов'язкові) заходи для поліпшення вихідного варіанта ER-діаграми за допомогою застосування процедури генералізації або спеціалізації сутностей, виділених на етапі 1.1.
При проведенні спеціалізації починаються спроби виділити розходження між сутностями. На противагу цьому при застосуванні методів генералізації здійснюється пошук загальних характеристик сутностей різних типів.
Із метою одержання наочного представлення основних сутностей і зв'язків, визначених у специфікаціях, ми побудували вихідну ER-діаграму, яка має вигляд, показаний на рисунку 13 (для представлення користувача директор) та на рисунку 14 (касир).
3.
Логічне проектування бази даних (кроки 2.1 – 2.6, 3.1 – 3.4)
Етап 2.
Побудувати і перевірити локальну логічну модель даних на основі представлення про предметну область кожного з типів користувачів.
Етап 2.1.
Перетворити локальну концептуальну модель даних у локальну логічну модель.
На цьому етапі слід перетворити концептуальну модель даних із метою видалення з неї всіх структур, реалізація яких у СУБД реляційного типу є складною. Бажаний результат може бути досягнутий за допомогою виконання таких дій, як:
1. Видалення зв’язків типу M:N.
2. Видалення складних зв’язків.
3. Видалення рекурсивних зв’язків.
4. Видалення зв'язків, що мають атрибути.
5. Видалення множинних атрибутів.
6. Повторний огляд зв'язків типу 1:1.
7. Видалення надлишкових зв'язків.
Видалення зв’
язків типу
M
:
N
На ER-діаграмі зв’язки такого типу відсутні.
Видалення складних зв’
язків
На ER-діаграмі відсутні будь які складні (не бінарні зв'язки). Усі зв'язки в концептуальній моделі є бінарними, тобто будь-який зв'язок існує тільки між двома сутностями.
Видалення рекурсивних зв'язків
Рекурсивних зв’язків у концептуальній моделі не було виявлено.
Видалення зв'язків, що мають атрибути
Присутність зв'язків з атрибутами може вказувати на наявність у моделі ще не виділених сутностей, але таких зв’язків немає у концептуальній моделі.
Видалення множинних атрибутів
У локальній концептуальній моделі даних множинні атрибути відсутні, тому ми просто переходимо до наступного етапу.
Повторний огляд зв'язків типу 1:1
У деяких випадках сутності, що беруть участь у зв'язку 1:1, можуть фактично представляти різні аспекти того самого об`єкта. З цієї причини рекомендується знову проаналізувати зміст усіх зв'язків типу 1:1, що існують у моделі даних. У нашому прикладі є зв'язок цього типу Клієнт має Авіаквиток
, однак зовсім очевидно, що сутності, що беруть участь у ньому, представляють різні об`єкти реального світу.
Видалення надлишкових зв'язків
У ER-діаграмі надлишкових зв’язків не виявлено.
Етап 2.2.
Визначити набір відношень, вихочи зі структури локальної логічної моделі даних.
На цьому етапі мають бути створені відношення, що представляють сутності і зв'язки, наявні у показаній на рисунку 15 локальній логічній моделі даних представлення користувача Директор
. Зв'язки між сутностями моделюються за допомогою механізму первинних і зовнішніх ключів. Для опису складу всіх створюваних відношень буде використовуватися мова DDL (українською мовою).
Для кожної наявної в моделі даних сутності варто створити відношення, що буде включати всі прості атрибути цієї сутності.
ВІДДІЛЕННЯ
(Номер_Відділення, Телефон, Факс, Поштовий_Код, E-mail).
Первинний ключ
- Номер_Відділення.
ПРАЦІВНИК
(Номер_Працівника, Ім
’я, Прізвище, По-батькові, Серія_Паспорту, Номер_Паспорту, Дата_Народження, Місце_Проживання, Телефон, Стать, ЗарПлата, Посада
).
Первинний ключ
– Номер_Працівника.
Зовнішній ключ
– Номер_Відділення.
КЛІЄНТ
(Номер_Клієнта, Ім’я, Прізвище, По-батькові, Серія_Паспорту, Номер_Паспорту, Дата_Народження, Місце_Проживання, Стать, Мета_Перельоту).
Первинний ключ
– Номер_Клієнта.
ЛІТАК
(Номер_Літака, Назва).
Первинний ключ
– Номер_Літака.
АВІАКВИТОК
(Номер_Авіаквитку, Номер_Клієнта).
Первинний ключ
– Номер_Авіаквитку.
Зовнішній ключ
– Номер_ Клієнта.
КЛАС
(Номер_Класу, Назва).
Первинний ключ
– Номер_Класу.
РЕЙС
(Номер_Рейсу, Номер_Напряму).
Первинний ключ
– Номер_Рейсу.
Зовнішній ключ
– Номер_Напряму.
НАПРЯМ
(Номер_Напряму, Пункт_Відправлення, Пункт_Прибуття).
Первинний ключ
– Номер_Напряму.
ТАБЛИЦЯ ПРОДАЖУ АВІАКВИТКІВ
(Номер_Запису, Номер_Працівника, Номер_Авіаквитку, Номер_Класу, Номер_Розкладу_Авіаперельотів).
Первинний ключ
– Номер_Запису.
Зовнішній ключ
- Номер_Працівника.
Зовнішній ключ
- Номер_Авіаквитку.
Зовнішній ключ
- Номер_Класу.
Зовнішній ключ
- Номер_Розкладу_Авіаперельотів.
РОЗКЛАД АВІА ПЕРЕЛЬОТІВ
(Номер_Запису, Номер_Літака, Номер_Рейсу)
Первинний ключ
– Номер_Запису.
Зовнішній ключ
- Номер_Літака..
Зовнішній ключ
- Номер_Рейсу.
Рисунок 15
Етап 2.3. Перевірка моделі за допомогою правил нормалізації
На цьому етапі необхідно перевірити створений для представлення користувача Директор
набір відношень на відповідність усім вимогам процедури нормалізації. Повний процес нормалізації відношень уключає наступні дії:
· приведення до першої нормальної форми (1НФ), що дозволяє видалити з відношень повторювані групи атрибутів;
· приведення до другої нормальної форми (2НФ), що дозволяє усунути часткову залежність атрибутів від первинного ключа;
· приведення до третьої нормальної форми (ЗНФ), що дозволяє усунути транзитивну залежність атрибутів від первинного ключа;
· приведення до нормальної форми Бойса-Кодда (НФБК), що дозволяє видалити з функціональних залежностей аномалії, що залишилися.
Щоб переконатися в тому, що кожне з відношень, описаних у додатку далі, знаходиться, як мінімум, у нормальній формі Бойса-Кодда (НФБК), ми проаналізуємо функціональні залежності між цими відношеннями. Якщо буде виявлене відношення, що не представлене в НФБК, це може означати, що або створена логічна модель структурно неправильна, або при визначенні на її основі повного набору відношень була допущена помилка. У будь-якому випадку буде потрібно повернутися до попереднього етапу і внести необхідні зміни.
ВІДДІЛЕННЯ
(Номер_Відділення, Телефон, Факс, Поштовий_Код, E-mail).
Первинний ключ
- Номер_Відділення.
Альтернативний ключ
-
Телефон
Номер_Відділення
-
Телефон, Факс, Поштовий_Код, E-mail.
Телефон
-
Номер_Відділення, Факс, Поштовий_Код, E-mail.
Факс
-
Номер_Відділення, Телефон, Поштовий_Код, E-mail.
Поштовий_Код
-
Номер_Відділення, Телефон, Факс, E-mail.
E-mail
-
Номер_Відділення, Телефон, Поштовий_Код, Факс.
ПРАЦІВНИК
(Номер_Працівника, Номер_Відділення, Ім
’я, Прізвище, По-батькові, Серія_Паспорту, Номер_Паспорту, Дата_Народження, Місце_Проживання, Телефон, Стать, ЗарПлата, Посада
).
Первинний ключ
– Номер_Працівника.
Номер_Працівника
-
Ім
’я, Прізвище, По-батькові, Серія_Паспорту, Номер_Паспорту, Дата_Народження, Місце_Проживання, Телефон, Стать, ЗарПлата, Посада
КЛІЄНТ
(Номер_Клієнта, Ім’
я, Прізвище, По-батькові, Серія_Паспорту, Номер_Паспорту, Дата_Народження, Місце_Проживання, Стать, Мета_Перельоту
).
Первинний ключ
– Номер_Клієнта.
Номер_Клієнта
-
Ім’
я, Прізвище, По-батькові, Серія_Паспорту, Номер_Паспорту, Дата_Народження, Місце_Проживання, Стать, Мета_Перельоту.
ЛІТАК
(Номер_Літака, Назва).
Первинний ключ
– Номер_Літака.
Номер_Літака
-
Назва.
АВІАКВИТОК
(Номер_Авіаквитку, Номер_Клієнта).
Первинний ключ
– Номер_Авіаквитку.
Зовнішній ключ
– Номер_ Клієнта.
Номер_Авіаквитку
-
Номер_ Клієнта.
КЛАС (Номер_Класу, Назва).
Первинний ключ
– Номер_Авіаквитку.
Номер_Класу
-
Назва.
РЕЙС
(Номер_Рейсу, Номер_Напряму, Назва).
Первинний ключ
– Номер_Рейсу.
Зовнішній ключ
– Номер_Напряму.
Номер_Рейсу
-
Номер_Напряму, Назва.
НАПРЯМ
(Номер_Напряму, Пункт_Відправлення, Пункт_Прибуття).
Первинний ключ
– Номер_Напряму.
Номер_Напряму
-
Пункт_Відправлення, Пункт_Прибуття.
ТАБЛИЦЯ ПРОДАЖУ АВІАКВИТКІВ
(Номер_Запису, Номер_Працівника, Номер_Авіаквитку, Номер_Класу, Номер_Розкладу_Авіаперельотів).
Первинний ключ
– Номер_Запису.
Зовнішній ключ
- Номер_Працівника.
Зовнішній ключ
- Номер_Авіаквитку.
Зовнішній ключ
- Номер_Класу.
Зовнішній ключ
- Номер_Розкладу_Авіаперельотів.
Номер_Запису
-
Номер_Працівника, Номер_Авіаквитку, Номер_Класу, Номер_Розкладу_Авіаперельотів.
РОЗКЛАД АВІА ПЕРЕЛЬОТІВ
(Номер_Запису, Номер_Літака, Номер_Рейсу)
Первинний ключ
– Номер_Запису.
Зовнішній ключ
- Номер_Літака.
Зовнішній ключ
- Номер_Рейсу.
Номер_Запису
-
Номер_Літака, Номер_Рейсу.
Після виконання процедури перевірки моделі за допомогою правил нормалізації для всіх відношень ми переконалися у тому, що всі відношення відповідають вимогам НФБК.
Етап 2.4. Перевірити модель у відношенні транзакцій користувачів.
Призначення цього етапу складається в перевірці локальної логічної моделі даних представлення Директор
у відношенні можливості виконання всіх транзакцій, передбачених специфікаціями. Для цієї мети ми використовуємо ER-діаграму, а також додану до неї документацію. Виходячи з цих даних, ми зробимо спробу виконати кожну з транзакцій вручну. Якщо це виявиться можливим для всіх транзакцій, необхідних відповідно до
специфікацій, то можна вважати, що дана логічна модель успішно перевірена. Якщо ж виконати вручну якусь із транзакцій виявиться неможливим, виходить, що у логічній моделі даних є помилка, яку варто усунути. Імовірніше всього, у моделі відсутня необхідна сутність, зв'язок або атрибут. У той же час, якщо деяка частина логічної моделі виявиться зайвою для виконання всього набору необхідних транзакцій, навіть з урахуванням можливості його розширення в майбутньому, є всі підстави думати, що ця частина моделі є надлишковою і підлягає видаленню з остаточного варіанта логічної моделі даних.
Етап 2.5. Створити діаграму сутність-зв’язок.
Остаточний варіант ER-діаграм логічної моделі даних для користувачів Директор
та Касир
залишився той самий після виконання усіх перевірок та показаний на малюнках 16 та 17 відповідно.
Етап 2.6. Визначити вимоги підтримки цілісності даних.
На цьому етапі ми визначимо ті вимоги підтримки цілісності даних, які необхідно реалізувати в локальній логічній моделі даних користувача Директор
. Їхнє призначення полягає в підтримці постійної внутрішньої погодженості інформації, організованої у вигляді бази даних. На цьому етапі наше завдання полягає в тому, щоб установити, які саме вимоги підтримки цілісності даних необхідні, а питання методів їх реалізації будуть вирішуватися пізніше. Ми розглянемо п'ять типів вимог підтримки цілісності:
· обов'язкові дані;
· обмеження для доменів атрибутів;
· цілісність сутностей;
· посилальна цілісність;
· вимоги даного підприємства.
Обов'язкові дані
Необхідно встановити, які з атрибутів завжди повинні містити одне з припустимих значень. Іншими словами, нас цікавлять атрибути, що завжди повинні мати конкретні значення, відмінні від NULL. Наприклад, атрибути номер, Ім'я працівника сутності Працівник завжди повинні містити значення, відмінні від порожнього.
Докладні зведення про атрибути, що входять у локальну модель даних користувача Директор,
були наведені при виконанні етапу 1.3 і представлені в додатку В до концептуального проектування БД.
Обмеження для доменів атрибутів
Домен атрибута встановлює набір припустимих значень, що можуть привласнюватися цьому атрибутові. Наприклад, набір припустимих значень для атрибута Номер
сутності Працівник
являє собою всі можливі рядки довжиною до 4 символів, що мають значення від 1 до 9999. Приклади доменів атрибутів логічної моделі даних користувача Директор
були наведені при виконанні етапу 1.4 і представлені в додатку Г.
Цілісність сутностей
Атрибут первинного ключа сутності не може мати значення NULL. Наприклад, кожен екземпляр сутності Відділення
обов'язково повинен мати конкретне значення атрибута його первинного ключа Номер_Відділення
. Атрибути, що входять у значення первинного ключа кожної сутності, були визначені при виконанні попередніх етапів Докладні зведення про ключі сутностей представлені в додатку.
Посилальна цілісність
Зв'язки між сутностями моделюються за допомогою приміщення в дочірнє відношення копії первинного ключа батьківського відношення. Поняття посилальної цілісності означає, що якщо зовнішній ключ дочірнього відношення містить деяке значення, то це значення повинне посилатися на існуюче і коректне значення ключа в батьківському відношенні. Атрибути, що входять до складу первинних і зовнішніх ключів різних сутностей, представлені в додатку В.
Підтримка посилальної цілісності організується за допомогою завдання необхідних обмежень для значень первинних і зовнішніх ключів. Ці обмеження визначають умови, яких слід дотримуватися при відновленні або видаленні значень первинного ключа, а також при вставці або відновленні значень зовнішнього ключа. Відзначимо, що вставка нового значення первинного ключа або видалення значення зовнішнього ключа не викликає яких-небудь проблем з посилальною цілісністю.
Для кожного зовнішнього ключа відношення варто вказати умови, що повинні виконуватися при відновленні або видаленні відповідного значення первинного ключа. У цьому випадку можна застосувати одну з пропонованих стратегій - NO ACTION
, CASCADE
, SET NULL
, SET DEFAULT
або NO CHECK
(див. додаток Д).
Вимоги даного підприємства
Ці вимоги, які інакше називаються бізнес-правилами, визначаються тими методами й обмеженнями, що прийняті на даному підприємстві щодо виконання різних операцій. Наприклад, у АТП установлено, що працівник може бути закріпленим лише за одним відділом. Основні бізнес-правила авіакомпанії представлені у додатку Е.
Етап 3.
Створити і перевірити глобальну логічну модель даних.
Етап 3.1. Злити локальну логічну модель даних у єдину глобальну модель даних.
На цьому етапі ми зіллємо дві локальні логічні моделі даних з метою створення глобальної логічної моделі даних, тобто глобального представлення для всієї авіакомпанії.
Процес злиття моделей даних ми почнемо з виявлення в них подібних елементів, після чого виконаємо пошук і видалення конфліктних областей. Завершить процедуру включення в глобальну модель унікальних областей кожної з вихідних локальних моделей. Деякі типові задачі, що доводиться вирішувати під час виконання злиття, нижче будуть проілюстровані на конкретних прикладах.
Аналіз імен сутностей і їхніх первинних ключів
Порівняємо імена сутностей і визначені для них первинні ключі кожної з локальних моделей, що зливаються.
Таблиця 3.1
Порівняння імен сутностей і їхніх первинних ключів у представленнях користувачів Директор і Касир
Тип сутності (представлення Директор)
|
Первинний ключ
|
Тип сутності (представлення Касир)
|
Первинний ключ
|
Відділення
|
Номер_Відділення
|
Відділення
|
Номер_Відділення
|
Працівник
|
Номер_Працівника
|
Працівник
|
Номер_Працівника
|
Табл. продажу авіаквитків
|
Номер_Запису
|
Табл. продажу авіаквитків
|
Номер_Запису
|
Авіаквиток
|
Номер_Авіаквитка
|
Авіаквиток
|
Номер_Авіаквитка
|
Клієнт
|
Номер_Клієнта
|
Клієнт
|
Номер_Клієнта
|
Клас
|
Номер_Класу
|
Клас
|
Номер_Класу
|
Розклад авіа перельотів
|
Номер_Запису
|
Розклад авіа перельотів
|
Номер_Запису
|
Рейс
|
Номер_Рейсу
|
Рейс
|
Номер_Рейсу
|
Напрям
|
Номер_Напряму
|
Напрям
|
Номер_Напряму
|
Попереднє порівняння імен сутностей і їх первинних ключів у кожному із представлень дозволяє виявити їх загальні ділянки, тобто ті області, у яких вони перекриваються.
Аналіз імен зв'язків
Тепер порівняємо імена присутніх у представленнях Директор
і Касир
зв'язків. Імена зв'язків, що існують у кожному із представлень, показані в табл. Кожен зв'язок представлений у таблиці тільки один раз і асоційований з її батьківською сутністю.
Таблиця 3.2
Порівняння зв'язків, наявних у представленнях Директор і Касир
Сутності
(представлення Директор)
|
Тип зв'язку
|
Тип сутності (представлення Директор)
|
Сутності (представлення Касир)
|
Тип зв'язку
|
Тип сутності (представлення Касир)
|
Відділення
|
Має
Знаходиться під керівництвом
|
Працівник
Директор
|
Відділення
|
Має
Знаходиться під керівництвом
|
Працівник
Директор
|
Працівник
|
Належить до
|
Відділення
|
Працівник
|
Належить до
|
Відділення
|
Директор
|
Керує
|
Відділення
|
Директор
|
Керує
|
Відділення
|
Касир
|
Фіксується у
|
Таблиця продажу авіаквитків
|
Касир
|
Фіксується у
|
Таблиця продажу авіаквитків
|
Екіпаж
|
Перебуває у
|
Літак
|
Екіпаж
|
Перебуває у
|
Літак
|
Клієнт
|
Одержує
|
Авіаквиток
|
Клієнт
|
Одержує
|
Авіаквиток
|
Авіаквиток
|
Фіксується у
Належить
|
Таблиця продажу авіаквитків
Клієнт
|
Авіаквиток
|
Фіксується у
Належить
|
Таблиця продажу авіаквитків
Клієнт
|
Клас
|
Належить до
|
Таблиця продажу авіаквитків
|
Клас
|
Належить до
|
Таблиця продажу авіаквитків
|
Напрям
|
Визначає
|
Рейс
|
Напрям
|
Визначає
|
Рейс
|
Рейс
|
Здійснюється у
|
Напрям
|
Рейс
|
Здійснюється у
|
Напрям
|
Рейс
|
Фіксується у
|
Розклад авіа перельотів
|
Рейс
|
Фіксується у
|
Розклад авіа перельотів
|
Таблиця продажу авіаквитків
|
Підпорядкована
Містить дані про
Містить дані про
Містить дані про
|
Розклад авіа перельотів
Касир
Авіаквиток
Клас
|
Таблиця продажу авіаквитків
|
Підпорядкована
Містить дані про
Містить дані про
Містить дані про
|
Розклад авіа перельотів
Касир
Авіаквиток
Клас
|
Літак
|
Фіксується у
Містить у собі
|
Розклад авіа перельотів
Екіпаж
|
Літак
|
Фіксується у
Містить у собі
|
Розклад авіа перельотів
Екіпаж
|
Розклад авіа перельотів
|
Містить дані з
Містить дані про
|
Таблиця продажу авіаквитків
Літак
Рейс
|
Розклад авіа перельотів
|
Містить дані з
Містить дані про
Містить дані про
|
Таблиця продажу авіаквитків
Літак
Рейс
|
Це попереднє порівняння імен зв'язків у кожному із представлень користувачів також допомагає уточнити ділянки, спільні для обох представлень. Однак із цього зовсім не випливає що можна покладатися на те, що сутності або зв'язок з тими ж іменами відіграють однакову роль у кожному із представлень. І все-ж таки, порівняння імен сутностей і зв'язків можна вважати дуже зручною вихідною точкою пошуку ідентичних ділянок у представленнях, що зливаються, якщо, звичайно, не забувати, про можливі помилки.
Злиття загальних сутностей з окремих локальних моделей
На даному етапі виконується перевірка імен і вмісту кожної сутності в обох представленнях. Зокрема, для ідентифікації еквівалентних сутностей з різними іменами варто проаналізувати їхні первинні ключі. Виконання даного етапу включає наступні дії:
· злиття сутностей з однаковими іменами й однаковими первинними ключами;
· злиття сутностей з однаковими іменами, що мають різні первинні ключі;
· злиття сутностей з різними іменами, що мають однакові або різні первинні ключі.
Злиття сутностей з однаковими іменами й однаковими первинними ключами.
Сутності, що мають в обох представленнях той самий первинний ключ, як правило, представляють ту саму концепцію реального світу. Ідентифікація й об'єднання подібних пар являє собою відносно нескладну задачу.
Злиття сутностей з однаковими іменами, що мають різні первинні ключі.
Такі сутності відсутні.
Злиття сутностей з різними іменами, що мають однакові або різні первинні ключі .
Такі сутності відсутні.
Включення (без злиття) сутностей, унікальних для кожного локального представлення.
Глобальне представлення
ВІДДІЛЕННЯ
(Номер_Відділення, Телефон, Факс, Поштовий_Код, E-mail).
Первинний ключ
- Номер_Відділення.
ЛІТАК
(Номер_Літака, Назва).
Первинний ключ
– Номер_Літака.
Злиття загальних зв'язків з окремих локальних моделей
На цьому етапі виконується аналіз імен і призначення всіх зв'язків, що є наявними в обох локальних представленнях. Перш ніж приступати до злиття зв'язків, дуже важливо усунути будь-які конфлікти, що стосуються їх кардинальності і ступеня участі сторін. Імена зв'язків, що наявні в обох локальних представленнях, утримуються в таблиці. Обов'язковою задачею, розв'язуваної на даному етапі, є злиття зв'язків, що мають однакові імена і подібне призначення, а також злиття зв'язків, що мають різні імена, але ідентичне призначення. Але в локальних логічних моделях обох представлень такі зв’язки не були виявлені.
Включення (без злиття) зв'язків, унікальних для кожного локального представлення
У таблиці можна виділити зв'язки, що є унікальними для кожного з
представлень. Для представлення користувача Директор
виявлені унікальні зв’язки: Директор керує Відділенням, Екіпаж перебуває у Літаку, Літак міститься у Розкладі авіа перельотів. Ці зв'язки повинні бути перенесені в глобальну модель даних без яких-небудь змін.
Етап 3.2. Перевірити глобальну логічну модель.
Хоча локальні логічні моделі даних представлень диспетчер та головний інженер були перевірені ще до виконання процедури їх злиття в глобальну логічну модель даних, існує імовірність того, що при виконанні цієї процедури в глобальну модель даних були внесені нові помилки. Зокрема, дуже важливо перевірити створену глобальну логічну модель даних на відповідність вимогам нормалізації і проконтролювати можливість виконання всіх необхідних транзакцій.
Перевірка на наявність пропущених сутностей і зв'язків
Перевірка на наявність пропущених сутностей і зв'язків, що існують між елементами представлень користувачів, що зливаються, є однією з найважливіших задач при створенні глобальної моделі даних. Однак часто ця задача є дуже складною. Сутності і зв'язки можуть залишитися за межами локальних представлень у тих випадках, коли має місце невизначеність із приводу того, хто відповідає за деякий вид діяльності. Кожний з користувачів може припускати, що відповідальність за виконання деякого завдання покладається на іншого користувача, і з цієї причини дані і транзакції, необхідні для виконання цього завдання, будуть відсутні в його локальному представленні. Найчастіше подібні проблеми мають місце в інтерфейсах між різними типами представлень.
Перевірка коректності зовнішніх ключів
На цьому етапі виконується перевірка того, чи всі дочірні сутності містять необхідні їм зовнішні ключі. Особливу обережність варто виявляти щодо тих сутностей і їхніх зв'язків, що були безпосередньо втягнуті в процес злиття представлень користувачів.
Перевірка дотримання обмежень цілісності
У глобальній моделі необхідно ще раз перевірити усі вимоги, необхідні для підтримки цілісності даних, і переконатися, що будь-які можливі конфлікти і протиріччя між локальними моделями даних були проаналізовані й усунуті.
Етап 3.3. Перевірити можливості розширення моделі в майбутньому.
Дуже важливо, щоб створена глобальна логічна модель даних допускала можливість її розширення в майбутньому при зміні вимог користувачів. Наприклад, директор авіакомпанії може прийняти рішення внести зміни в методи обліку авіа перельотів чи методи обліку продажу квитків клієнтам. Існуюче глобальне представлення компанії повинне допускає внесення необхідних доповнень, що відбивають подібні зміни в діяльності фірми.
Етап 3.4. Створити остаточний варіант діаграми сутність-зв’язок.
Остаточна версія логічного глобального представлення показана на рис. 18.
ВИСНОВОК
В даній курсовій роботі розглянута теоритичне моделюваня бази даних авіакомпанії для користувачів директор та касир з продажу авіаквитків. Курсова робота складається з трьох основних частин, в яких поетапно розглядається і зображується схематично основні зв’язки директор, касир та загальна схема їх відношень. Дані, основні визначення та поняття, застосована методологія концептуального проектування. Побудована локальна концептуальна модель даних для представлення користувача «Директор», визначені основні типи сутностей, зв’язки та атрибути, які зв’язані з ними. Створена діаграма «сутність-зв’язок», яка графічно демонструє вище зазначені зв’язки. На другому етапі розглянуто логічне проектування бази даних. Третій етап присвячено створенню і перевірці глобальної логічної моделі даних.
Розробка даної курсової роботи дала мені можливість більш детально уявити роботу авіакомпанії, набути та поглибити знання з даного предмету.
СПИСОК ЛІТЕРАТУРНИХ ДЖЕРЕЛ
1
. Дейт К.Дж. Введение в системы баз данных. 6-е издание. Диалектика. Киев – Москва. 1998 г. 784 с.
2
. Хансен Г., Хансен Дж. Базы данных: разработка и управление. Бином. Москва. 1999 г. Пер. с англ. 700 с.
3
. Коннолли Т., Бегг К., Страчан А. Базы данных: проектирование, реализация и сопровождение. Теория и практика. 2-е издание. Вильямс. Москва-Санкт-Петербург-Киев. 2000 г. 1111 с.
4
. Кириллов В.В. Основы проектирования реляционных баз данных. Учебное пособие. Санкт-Петербургский Государственный институт точной механики и оптики (технический университет). Кафедра вычислительной техники. - http://www.cs.ifmo.ru
5
. С.Д. Кузнецов Основы современных баз данных. Информационно-аналитические материалы. - http://www.citmgu.ru/
Додаток
А
Ім’я сутності
|
Опис
|
Особливості використання
|
Відділення
|
Місце роботи
|
Одне і більше відділень авіакомпанії
|
Працівник
|
Загальний термін. Описує весь персонал, який працює у авіакомпанії.
|
Кожен із працівників належить до певного відділення.
|
Директор
|
Керуючий відділеннями
|
Здійснює контроль над всіма відділеннями авіакомпанії
|
Касир
|
Персонал, що продає авіаквитки
|
Здійснює, продаж, реєстрацію квитків та внесення даних у базу даних
|
Екіпаж
|
Персонал, що знаходиться у літаку під час перельоту
|
Відповідає за безпечне та комфортне транспортування пасажирів
|
Літак
|
Пристрій для транспортування пасажирів
|
Використовується для надання послуг авіакомпанією
|
Рейс
|
Певний переліт
|
Використовується для ідентифікації авіа перельоту
|
Напрям
|
Певний маршрут літака
|
Використовується для відображення пунктів відправлення та прибуття літака
|
Авіаквиток
|
Документ для здійснення авіа перельоту пасажиром
|
Підтверджує легальність перельоту пасажиром
|
Таблиця продажу авіаквитків
|
Таблиця
|
Кожен запис таблиці відображає факт продажу авіаквитка.
|
Розклад авіа перельотів
|
Таблиця
|
Кожен запис цієї таблиці відображає факт здійснення певного авіа перельоту
|
Додаток
Б
Зведення про типи зв’язків
Тип сутності
|
Тип зв’язку
|
Тип сутності
|
Кардинальність
|
Відділення
|
Має
Знаходиться під керівництвом
|
Працівник
Директор
|
1:М
М:1
|
Працівник
|
Належить до
|
Відділення
|
М:1
|
Директор
|
Керує
|
Відділення
|
1:M
|
Касир
|
Фіксується у
|
Таблиця продажу авіаквитків
|
1:М
|
Екіпаж
|
Перебуває у
|
Літак
|
М:1
|
Клієнт
|
Одержує
|
Авіаквиток
|
1:1
|
Авіаквиток
|
Фіксується у
Належить
|
Таблиця продажу авіаквитків
Клієнт
|
1:1
1:1
|
Клас
|
Належить до
|
Таблиця продажу авіаквитків
|
1:М
|
Напрям
|
Визначає
|
Рейс
|
1:М
|
Рейс
|
Здійснюється у
|
Напрям
|
М:1
|
Рейс
|
Фіксується у
|
Розклад авіа перельотів
|
1:1
|
Таблиця продажу авіаквитків
|
Підпорядкована
Містить дані про
Містить дані про
Містить дані про
|
Розклад авіа перельотів
Касир
Авіаквиток
Клас
|
М:1
М:1
1:1
М:1
|
Літак
|
Фіксується у
Містить у собі
|
Розклад авіа перельотів
Екіпаж
|
1:М
|
Розклад авіа перельотів
|
Містить дані з
Містить дані про
Містить дані про
|
Таблиця продажу авіаквитків
Літак
Рейс
|
1:М
М:1
1:1
|
Зведення про атрибути
Тип сутності
|
Атрибут
|
Опис
|
Тип даних, довжина
|
Обмеження
|
Значення за замовчуванням
|
Псевдонім
|
Допустимість Null
|
Похідний
|
Відділення
|
Номер
|
Унікальний ідентифікатор відділення
|
Символьний, до 3 символів
|
Первинний ключ
|
Ні
|
Ні
|
Телефон
|
Номер телефону відділення
|
Символьний, фіксований, 13 символів
|
Альтернативний ключ
|
Ні
|
Ні
|
Факс
|
Номер факсу відділення
|
Символьний, фіксований, 13 символів
|
Альтернативний ключ
|
Ні
|
Ні
|
Поштовий код
|
Поштовий код відділення
|
Символьний, фіксований, 13 символів
|
Альтернативний ключ
|
Ні
|
Ні
|
E-mail
|
Електронна адреса відділення
|
Символьний, фіксований, 25 символів
|
Альтернативний ключ
|
Так
|
Ні
|
Працівник
|
Номер
|
Унікальний ідентифікатор співробітника
|
Символьний, до 5 символів
|
Первинний ключ
|
Ні
|
Ні
|
Номер відділення
|
Унікальний ідентифікатор відділення
|
Символьний, до 3 символів |
Так
|
Ні |
Повне ім’я
|
Ім'я працівника (складений атрибут, включає атрибути Прізвище, Ім’я і По-Батькові)
|
Ім’я
|
Ім'я працівника
|
Символьний, до 15 символів
|
Ні
|
Ні
|
Прізвище
|
Прізвище працівника
|
Символьний, до 15 символів
|
Ні
|
Ні
|
По-батькові
|
По-батькові працівника
|
Символьний, до 20 символів
|
Ні
|
Ні
|
Паспортні дані
|
Складений атрибут, включає атрибути Серія, Номер паспорту, Дата народження, Місце проживання
|
Символьний, до 15 символів
|
Альтернативний ключ
|
Ні
|
Ні
|
Серія паспорту
|
Серія паспорту
|
Символьний, до 2 символів
|
Ні
|
Ні
|
Номер паспорту
|
Номер паспорту
|
Символьний, до 6 символів
|
Ні
|
Ні
|
Дата народження
|
Дата народження
|
Дата
|
Ні
|
Ні
|
Місце проживання
|
Місце проживання працівника
|
Символьний, до 50 символів
|
Ні
|
Ні
|
Телефон
|
Номер телефону працівника
|
Символьний, фіксований, 13 символів
|
Так
|
Ні
|
Стать
|
Стать працівника
|
Символьний, фіксований, 1 символ
|
Ні
|
Ні
|
Зар. Плата
|
Заробітна плата працівника у національній валюті
|
Грошовий
|
Ні
|
Ні
|
Посада
|
Посада, займана працівником
|
Символьний до 20 символів
|
Ні
|
Ні
|
Клієнт
|
Номер
|
Унікальний ідентифікатор клієнта
|
Символьний, до 5 символів
|
Первинний ключ
|
Ні
|
Ні
|
Повне ім’я
|
Повне ім'я клієнта (складений атрибут, включає атрибути Прізвище, Ім’я і По-Батькові)
|
Ім’я
|
Ім'я клієнта
|
Символьний, до 15 символів
|
Ні
|
Ні
|
Прізвище
|
Прізвище клієнта
|
Символьний, до 15 символів
|
Ні
|
Ні
|
По-батькові
|
По-батькові клієнта
|
Символьний, до 20 символів
|
Ні
|
Ні
|
Паспортні дані
|
Складений атрибут, включає атрибути Серія, Номер паспорту, Дата народження, Місце проживання
|
Символьний, до 15 символів
|
Альтернативний ключ
|
Ні
|
Ні
|
Серія паспорту
|
Серія паспорту
|
Символьний, до 2 символів
|
Ні
|
Ні
|
Номер паспорту
|
Номер паспорту
|
Символьний, до 6 символів
|
Ні
|
Ні
|
Стать
|
Стать клієнта
|
Символьний, фіксований, 1 символ
|
Ні
|
Ні
|
Мета перельоту
|
Мета перельоту за кордон
|
Символьний, 50 символів
|
Ні
|
Ні
|
Директор
|
Ті, що для сутності Працівник
|
Визначає працівника, який займає посаду директора
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Касир
|
Ті, що для сутності Працівник
|
Визначає працівника, який займає посаду директора
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Екіпаж
|
Ті, що для сутності Працівник
|
Визначає працівника, який займає посаду директора
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Ті, що для сутності Працівник
|
Літак
|
Номер
|
Унікальний ідентифікатор літака
|
Символьний, до 3 символів
|
Первинний ключ
|
Ні
|
Ні
|
Назва
|
Назва літака
|
Символьний, до 15 символів
|
Ні
|
Ні
|
Авіаквиток
|
Номер
|
Унікальний ідентифікатор авіаквитка
|
Символьний, до 3 символів
|
Первинний ключ
|
Ні
|
Ні
|
Номер клієнта
|
Унікальний ідентифікатор клієнта
|
Символьний, до 5 символів
|
Ні
|
Ні
|
Клас
|
Номер
|
Унікальний ідентифікатор класу
|
Символьний, до 3 символів
|
Первинний ключ
|
Ні
|
Ні
|
Назва
|
Назва класу
|
Символьний, до 15 символів
|
Ні
|
Ні
|
Рейс
|
Номер
|
Унікальний ідентифікатор рейсу
|
Символьний, до 3 символів
|
Первинний ключ
|
Ні
|
Ні
|
Номер напряму
|
Унікальний ідентифікатор напряму
|
Символьний, до 3 символів
|
Ні
|
Ні
|
Назва
|
Назва рейсу
|
Символьний, до 15 символів
|
Ні
|
Ні
|
Напрям
|
Номер
|
Унікальний ідентифікатор напряму
|
Символьний, до 3 символів
|
Первинний ключ
|
Ні
|
Ні
|
Пункт відправлення
|
Пункт відправлення
|
Символьний, до 15 символів
|
Ні
|
Ні
|
Пункт прибуття
|
Пункт прибуття
|
Символьний, до 15 символів
|
Ні
|
Ні
|
Таблиця продажу авіаквитків
|
Номер
|
Номер запису у таблиці продажу авіаквитків (унікальний)
|
Символьний, до 3 символів
|
Первинний ключ
|
Ні
|
Ні
|
Номер розкладу
|
Унікальний ідентифікатор розкладу
|
Символьний, до 3 символів
|
Ні
|
Ні
|
Номер працівника
|
Унікальний ідентифікатор працівника
|
Символьний, до 5 символів
|
Ні
|
Ні
|
Номер авіаквитка
|
Унікальний ідентифікатор авіаквитка
|
Символьний, до 3 символів
|
Ні
|
Ні
|
Номер класу
|
Унікальний ідентифікатор класу
|
Символьний, до 3 символів
|
Ні
|
Ні
|
Розклад авіа перельотів
|
Номер
|
Номер запису у таблиці продажу авіаквитків (унікальний)
|
Символьний, до 3 символів
|
Первинний ключ
|
Ні
|
Ні
|
Додаток Г
Зведення про домени атрибутів поміщених у документацію
Ім'я домена
|
Характеристики домена
|
Зразки припустимих значень
|
Табельний Номер
|
Рядок перемінної довжини, до 5 символів
|
А0001, А0002, В0003, В0004
|
Вулиця
|
Рядок перемінної довжини, до 25 символів
|
вул. Шевченка, 10 кв. 44
|
Телефон
|
Рядок перемінної довжини, до 13 символів
|
8-050-30-44-702
|
Стать
|
Рядок довжиною в 1 символ (значення „Ч” або „Ж”)
|
Ч, Ж
|
Додаток Д
Опис у вигляді мови DDL для кожного відношення для представлення користувача
Директор
ВІДДІЛЕННЯ
(Номер_Відділення, Телефон, Факс, Поштовий_Код, E-mail).
Первинний ключ
- Номер_Відділення.
ПРАЦІВНИК
(Номер_Працівника, Ім
’я, Прізвище, По-батькові, Серія_Паспорту, Номер_Паспорту, Дата_Народження, Місце_Проживання, Телефон, Стать, ЗарПлата, Посада
).
Первинний ключ
– Номер_Працівника.
КЛІЄНТ
(Номер_Клієнта, Ім’
я, Прізвище, По-батькові, Серія_Паспорту, Номер_Паспорту, Дата_Народження, Місце_Проживання, Стать, Мета_Перельоту
).
Первинний ключ
– Номер_Клієнта.
ЛІТАК
(Номер_Літака, Назва).
Первинний ключ
– Номер_Літака.
АВІАКВИТОК
(Номер_Авіаквитку, Номер_Клієнта).
Первинний ключ
– Номер_Авіаквитку.
Зовнішній ключ
– Номер_ Клієнта посилання
Клієнт (Номер_Клієнта) при видаленні
NO ACTION при зміні
CASCADE.
РЕЙС
(Номер_Рейсу, Номер_Напряму).
Первинний ключ
– Номер_Рейсу.
Зовнішній ключ
–
Номер_Напряму
посилання
Напрям (
Номер_Напряму
)
при видаленні
CASCADE при зміні
CASCADE.
КЛАС
(Номер_Класу, Назва).
Первинний ключ
– Номер_Класу.
НАПРЯМ
(Номер_Напряму, Пункт_Відправлення, Пункт_Прибуття).
Первинний ключ
– Номер_Напряму.
ТАБЛИЦЯ ПРОДАЖУ АВІАКВИТКІВ
(Номер_Запису, Номер_Працівника, Номер_Авіаквитку, Номер_Класу, Номер_Розкладу_Авіаперельотів).
Первинний ключ
– Номер_Запису
Зовнішній ключ
– Працівник (Номер_Працівника) посилання
Працівник (Номер_Працівника) при видаленні
NO ACTION при зміні
CASCADE.
Зовнішній ключ
– Авіаквиток (Номер_Авіаквитку) посилання
Авіаквиток (Номер_Авіаквитку) при видаленні
NO ACTION при зміні
CASCADE.
Зовнішній ключ
- Номер_Класу посилання
Клас (Номер_Класу) при видаленні
NO ACTION при зміні
CASCADE.
Зовнішній ключ
- Номер_Розкладу_Авіаперельотів посилання
РОЗКЛАД АВІА ПЕРЕЛЬОТІВ(Номер_Розкладу_Авіаперельотів) при видаленні
NO ACTION при зміні
CASCADE.
РОЗКЛАД АВІА ПЕРЕЛЬОТІВ
(Номер_Запису, Номер_Літака, Номер_Рейсу)
Первинний ключ
– Номер_Запису.
Зовнішній ключ
- Номер_Літака посилання
Літак (Номер_Літака) при видаленні
NO ACTION при зміні
CASCADE.
Зовнішній ключ
- Номер_Рейсу посилання
Рейс (Номер_Рейсу) при видаленні
NO ACTION при зміні
CASCADE.
Додаток Е
1. Кожен літак має налічувати не більше ніж 6 членів екіпажу.
2. Заробітна плата кожного працівника повинна бути не менше встановленого державою мінімуму.
3. Кожен авіа переліт повинен налічувати не більше 90 клієнтів (пасажирів).
4. У кожному напрямі має бути передбачено мінімум 5 рейсів.
Умовні позначення на ER-діаграмах
-- зв’язок між сильними типами сутності;
|
|
-- зв’язок між сильним і слабким
типами сутності;
|
|
-- частковий ступінь участі сутності;
|
|
-- кардинальність „один до одного”;
|
|
_________