Уявлення про даталогічне проектування
Даталогічна модель являє собою базу даних, структуровану на логічному рівні й орієнтовану на конкретну СУБД.
Починається даталогічне проектування з вибору СУБД.
Основні факторами, що впливають на даталогічне проектування з боку СУБД:
1. Тип логічної моделі, що його підтримує вибрана СУБД. Найпоширенішими на ринку програмних засобів і в практиці інформаційного забезпечення є реляційні СУБД. Крім реляційних моделей ще існують ієрархічні й сіткові моделі баз даних.
2. Особливості фізичної організації даних у середовищі вибраної СУБД. Наприклад, у СУБД Paradox чи dBASE-системах база даних організована у вигляді набору взаємозв'язаних файлів, усі інші об'єкти, такі як форми та звіти, також зберігаються в окремих файлах. У середовищі Access усі дані та інструментальні засоби роботи з ними зберігаються в єдиному файлі бази даних.
3. Кількісні обмеження, які накладає СУБД (наприклад, кількість рівнів ієрархії в ієрархічних моделях, можлива кількість полів, записів, файлів тощо).
Компоненти СУБД:
ядро, яке відповідає за управління даними у зовнішній і оперативної пам'яті і журналізацію;
процесор мови бази даних, що забезпечує оптимізацію запитів на вилучення та зміну даних і створення, як правило, машинно-незалежного виконуваного внутрішнього коду;
підсистему підтримки виконання, яка інтерпретує програми маніпуляції даними, що створюють користувальницький інтерфейс із СУБД;
сервісні програми (зовнішні утиліти), що забезпечують ряд додаткових можливостей по обслуговуванню інформаційної системи.
- Ієрархічні СУБД
- Мережеві (сіткові) СУБД - побудовані на основі мережевої моделі даних.
Вузол - це сукупність атрибутів даних, що описують деякий об'єкт. На схемі ієрархічного дерева вузли представляються вершинами графа. У мережевій структурі кожен елемент може бути пов'язаний з будь-яким іншим елементом.
Мережеві бази даних подібні ієрархічним, за винятком того, що в них є покажчики в обох напрямках, які з'єднують споріднену інформацію.
Реляційна модель даних являє безліч взаємопов'язаних таблиць, кожна з яких містить інформацію про об'єкти певного виду. Рядок таблиці містить дані про конкретний екземпляр (наприклад, автомобіль, клієнт), а стовпчики таблиці містять різні характеристики цих об'єктів - атрибути (наприклад, номер двигуна, телефони фірм).
Рядки таблиці називаються записами. Усі записи таблиці мають однакову структуру - вони складаються з полів (елементів даних), в яких зберігаються атрибути об'єкта. Кожне поле запису містить одну характеристику об'єкта і являє собою заданий тип даних (наприклад, текст, число, дата). Для ідентифікації записів використовується первинний ключ. Первинним ключем називається набір полів таблиці, комбінація значень яких однозначно визначає кожний запис у таблиці.
- Реляційні СУБД - побудовані на основі реляційної моделі даних.
- Об'єктно-реляційна СУБД – (різновид реляційної СУБД), що підтримує деякі технології, які реалізують об'єктно-орієнтований підхід: об'єкти, класи та успадкування реалізовані в структурі баз даних і мовою запитів. Об'єктно-реляційними СУБД є широко відомі Oracle Database, Informix, DB2, PostgreSQL.
За ступенем розподіленості
- Локальні СУБД (всі частини локальної СУБД розміщуються на одному комп'ютері);
- Розподілені СУБД (частини СУБД можуть розміщуватися на двох і більше комп'ютерах).
За способом доступу до БД
- Що вбудовуються. Вбудована СУБД - СУБД, яка може поставлятися як складова частина деякого програмного продукту, не вимагаючи процедури самостійної установки. Вбудована СУБД призначена для локального зберігання даних свого застосування і не розрахована на колективне використання в мережі. Фізично вбудована СУБД найчастіше реалізована у вигляді підключається бібліотеки. Доступ до даних з боку додатки може відбуватися через SQL або через спеціальні програмні інтерфейси.
Приклади: OpenEdge, SQLite, BerkeleyDB, Firebird Embedded, Microsoft SQL Server Compact, Лінтер.
За стратегією роботи з зовнішньою пам'яттю
- СУБД з безпосередньою записом - це СУБД, в яких всі змінені блоки даних негайно записуються в зовнішню пам'ять при надходженні сигналу підтвердження будь-якої транзакції. Така стратегія використовується тільки при високій ефективності зовнішньої пам'яті.
- СУБД з відкладеним записом - це СУБД, в яких зміни акумулюються в буферах зовнішньої пам'яті до настання будь-якого з наступних подій:
Така стратегія дозволяє уникнути частого обміну із зовнішньою пам'яттю і значно збільшити ефективність роботи СУБД.
Слід вміти спрогнозувати перспективи розвитку того підприємства, для якого робиться цей вибір з точки зору перспективи розширення функцій і задач, а також потрібно вивчити ринок програмних засобів.
При виборі СУБД виділяють два підходи до її оцінки.
Перший підхід пов'язаний з вибором з точки зору користувача, а другий — суто технічний-пов'язаний з продуктивністю системи.
Ураховуючи ці дві точки зору СУБД можна вибирати на підставі їх аналізу за такими параметрами.
2. Управління даними. До цих факторів належать:
можливість підтримувати записи змінної довжини, багатозначні атрибута і двонапрямлені зв'язки;
наявність засобів автоматизації проектування;
підтримка та автоматизоване ведення словника даних;
автоматизоване протоколювання роботи системи (фіксація часу, паролів користувачів і стану системи при вході в БД і виході з неї, статистика роботи системи тощо);
наявність засобів контролю з боку системи за внесенням змін з точки зору збереження посилкової цілісності;
наявність засобів автоматизованого відновлення й захисту інформації (криптографування, шифрування даних тощо).
4. Засоби підтримки роботи в мережі. Параметрами, які визначають можливість роботи в мережі, є такі:
можливість роботи в глобальній мережі;
можливість роботи в локальній мережі;
наявність автоматизованих засобів стеження за узгодженістю та цілісністю даних мережі при колективному використанні даних. Зокрема, на початку виконання запиту роблять копії всіх файлів, які беруть участь у його реалізації. Таким чином можна виконувати запити будь-якої складності, тому що всі коректури, внесені іншими користувачами в файли БД протягом виконання запиту, не впливають на його результат;
наявність механізму встановлення замків чи виконання захватів при паралельному внесенні змін у файли БД. Замок чи захват встановлюється на файл ВД на період внесення змін одним користувачем. Замок захищає лише від паралельного внесення змін; файл доступний для проведення всіх інших операцій;
механізм стеження за часом виконання транзакцій. Цей механізм необхідний для попередження зависання системи при колективному використанні даних. Якщо ліміт допустимого часу для виконання транзакції вичерпано, то її відмінюють, і БД повертається в початковий стан.
1. Усі атрибути відношень мають бути атомарними, тобто неподільними.
2. Відношення не повинно мати дублюючих рядків і стовпчиків.
3. Усі атрибути у відношенні повинні мати унікальні імена.
Для СУБД, що не підтримують статичних зв'язків між реляційними відношеннями зв'язки між відношеннями встановлюються лише для розв'язування конкретної задачі та існують на період її розв'язування.
Тому при відображенні інфологічної моделі на реляційну всі структурні зв'язки не описують у явному вигляді, а лише виконують перевірку на можливість установлення цих зв'язків. Обов'язковою умовою встановлення зв'язку між двома реляційними відношеннями є наявність у хоча б одного спільного атрибута, що є ключем, за яким виконується зв'язок.
Об'єктними будуть ті відношення, що вміщують нормативно-довідкові дані й первинні ключі яких не можуть дублюватися. Ці відношення можуть бути віднесеними до умовно-постійних файлів.
З'язковими відношеннями будуть ті відношення, що вміщують оперативні дані й ключі яких можуть дублюватися.
О'єктні відношення в схемі будуть головними. Тому при відображенні необхідно перевірити всі об'єкти-власники інфологічної моделі і залишити лише ті зв'язки, власниками яких є об'єктні відношення.
Зв'язкові відношення в схемі реляційної бази даних виступають як підпорядковані. Отже, у структурних зв'язках, що залишились від попередньої ітерації, необхідно перевірити підпорядковані об'єкти і залишити лише ті зв'язки, підпорядкованими в яких є зв'язкові відношення. Об'єкти-зв'язки перетворюються в самостійні рівноправні реляційні відношення.
Отриману в результаті відображення модель потрібно ще раз перевірити на відповідність її вимогам ЗНФ (4НФ).
Роботи першого етапу
Ієрархічні моделі, збудовані на основі принципу підпорядкованості між інформаційними об'єктами. Являють собою деревоподібну структуру, яка складається з вузлів (сегментів) і дуг (гілок).
Кожний вузол — це сукупність логічно взаємозв'язаних атрибутів, що описують певну сутність ПО, неорієнтовані дуги вказують на інформаційні зв'язки між ними.
При відображенні ІЛМ на ієрархічну інформаційні об'єкти потрібно трансформувати в сегменти, а структурні зв'язки — в неорієнтовані дуги.
Правило 1. На самому верхньому рівні ієрархії знаходиться лише один сегмент, який називається кореневим. Кожний екземпляр цього сегмента починає один логічний запис. Тому пошук в ієрархічних моделях виконують згори вниз, зворотного шляху пошуку в цих моделях немає.
Першим кроком відображення інфологічної моделі на ієрархічну буде вибір з-поміж інформаційних об'єктів ІЛМ кореневого сегмента. Ним може бути об'єкт, який не має зв'язків на вході з іншими об'єктами, тобто до нього не входить жодна дуга і він у всіх структурних зв'язках характеризується лише як власник структурного зв'язку. Якщо з-поміж об'єктів ІЛМ немає такого об'єкта, тоді серед них вибирають той, що має мінімальну кількість зв'язків на вході. Якщо ж, навпаки, на роль кореня є кілька об'єктів-претендентів, то тут може бути дві альтернативи.
Перша — об'єднати такі об'єкти-претенденти в один об'єкт і оголосити його кореневим сегментом.
Друга — якщо сегменти неможливо об'єднати через семантичну різнорідність, то кожний із цих об'єктів оголошують коренем різних фізичних баз даних, тобто будують кілька деревоподібних структур.
Тому другим кроком відображення є аналіз інформаційних об'єктів і виявлення з-поміж них ієрархічної підпорядкованості за принципом: «рід - вид», «ціле - частина», «причина - наслідок» і т.п. Аналіз виконують між об'єктами, які зв'язані зв'язками ВП чи ВПВ (друга частина ПВ ігнорується). В результаті цього аналізу об'єкти розміщуються по рівнях ієрархії.
Правило 3. В ієрархічній моделі підтримуються лише такі типи співвідношень між даними: 1:1 і 1:Б. Тому потрібно перевірити типи співвідношень між даними і обмежитися лише названими. Далі буде розглянуто, як в ієрархічних моделях можна реалізувати інші типи співвідношень.
Правило 4. Кожний вихідний сегмент може мати кілька породжених, але породжений сегмент може мати щонайбільше два вихідних, один з яких є фізично, а інший логічно вихідним. Зв'язки в одній фізичній базі даних (ФБД) називаються фізичними, а зв'язки між двома ФБД — логічними
За описаним правилом побудови зв'язків необхідно перевірити всі породжені сегменти на виконання зазначеного обмеження.
Надлишкові зв'язки потрібно усунути, об'єднанням кількох об'єктів в один, якщо це можливо, чи простим абстрагуванням від деяких зв'язків.
Приклад: ієрархічна СУБД накладає такі обмеження на логічну модель БД:
1. СУБД підтримує лише співвідношення типу 1:1 і 1:Б.
2. Кількість атрибутів у сегменті не повинна перевищувати 254.
3. Кількість рівнів ієрархії — не більше 15.
4. На логічно породжені сегменти накладається ряд обмежень:
4.1. Кореневий сегмент не може бути логічно породженим, але може бути логічно вихідним.
4.2. Логічно породжений сегмент може мати лише один логічно вихідний сегмент.
Так, на рисунку із наведених зв'язків А і В може існувати лише А. Зв’язок L, при якому кореневий сегмент X стає логічно породженим, взагалі не допускається.
Відповідно до цих вимог і обмежень має бути модифікована ієрархічна БД, яка працюватиме в середовищі зазначеної СУБД.
Наприклад. Як зазначалося, в ієрархічних моделях не можна підтримувати багатозначні зв'язки в явному виді. Тому якщо потрібно реалізувати співвідношення зазначеного типу, використовують такий штучний засіб, як адресне посилання. Для цього необхідно, щоб сегменти, між якими необхідно встановити зв'язок Б:Б, були розміщені в різних ФБД.
Ще одна особливість ієрархічних моделей пов'язана з виконанням технологічних операцій з актуалізації БД. При вилученні екземпляра вихідного сегмента також вилучаються всі пов'язані з ним екземпляри породжених сегментів, тобто весь логічний запис. Екземпляр породженого сегмента не може існувати без відповідного екземпляра вихідного. Наприклад, неможливо внести інформацію про нове обладнання, не внісши відповідних даних про деталі, які будуть оброблятись на цих верстатах, за наявності співвідношення вихідний-породжений між сегментами ДЕТАЛЬ : ВЕРСТАТ.
Тому процедури вилучення чи поповнення ієрархічної БД необхідно завжди виконувати дуже ретельно та уважно, щоб не знищити важливих даних чи, навпаки, не використати штучні дані.
Основними структурними елементами моделей цього типу є агрегат, запис і набір даних.
При відображенні ІЛМ на сіткову інформаційним об’єктам ставлять у відповідність записи. Кожний запис вміщує деяку множину атрибутів. Розрізняють такі поняття, як «тип запису» і «екземпляр запису. Тип запису — це абстрактні характеристики, а «екземпляр запису» – їх конкретні значення. Наприклад, тип запису: ПОСТАЧАЛЬНИК (код постачальника, назва постачальника, адреса постачальника, телефон), екземпляром цього типу запису буде: 105, Вега ЛТД, Київ-147, вул. Бойченка, 75, 552-33-98. Отже, кожному типу запису в БД може відповідати деяка сукупність екземплярів.
Усередині запису можуть виділятись агрегати. Агрегат — це поіменована сукупність логічно взаємозв'язаних атрибутів усередині типу запису. Ними можуть бути вектори, групи і групи, що повторюються.
Тут атрибут «іноземна мова» може мати кілька значень, його можна зобразити у вигляді вектора. Причому в одному запису може бути кілька векторів. Крім векторів у структурі запису сіткової моделі можуть бути й групи, в тому числі групи, що повторюються. Але при проектуванні слід пам'ятати, що групи, що повторюються, можна включати до запису при невеликій кількості екземплярів; якщо ця група бере участь у будь-яких інших зв'язках, то краще її виділити в окремий файл.
Звертаючись до даних, можна звертатись як до запису в цілому, так і до окремих його агрегатів.
Отже, запис — це агрегат, який не входить до складу інших агрегатів і є основною одиницею обробки БД (записи запам'ятовуються, вилучаються, поповнюються).
Тип набору ЗАМОВЛЕННЯ може характеризуватись екземпляром типу запису-власника ПОСТАЧАЛЬНИК і деякою множиною екземплярів типу запису МАТЕРІАЛ. Отже, кожний екземпляр набору складається з одного екземпляра типу запису-власника і кількох екземплярів типу записів-членів.
Постачальник
Матеріал
1:Б
Власник типу набору має бути обов'язково унікальним.
Записи-власники можуть брати участь у кількох наборах, а записи-члени можуть виступати як власники в інших наборах. Кожний тип набору ідентифікується унікальним іменем.
ЗАМОВЛЕННЯ
Набір першого класу об'єднує два типи запису. Підпорядкований запис жорстко пов'язаний із записом-власником і його можна виключити з групового відношення тільки видаливши. При видаленні запису-власника всі підлеглі записи автоматично теж видаляються.
В наборах другого класу допускається перемикання підпорядкованого запису на іншого власника, але неможливо його існування без власника. Для видалення запису-власника необхідно, щоб він не мав підлеглих записів з обов'язковим членством.
Сингулярний набір (тільки один екземпляр). У такого набору немає природного власника і в якості нього виступає система. Надалі такі набори можуть придбати запис-власника. Можна виключити запис з групового відношення, але зберегти її в базі даних не прикріплюючи до іншого власника. При видаленні запису-власника її підлеглі записи - необов'язкові члени зберігаються в базі, не беручи участь більше в груповому відношенні такого типу.
Ім’я набору
Відображення інфологічної моделі на сіткову починається з аналізу структурних зв'язків в ІЛМ.
Перетворення 1. У сітковій моделі можна залишати лише зв'язки типу ВП, а зв'язки ПВ і ВПВ повинні бути перетворені. Це можливо об'єднанням об'єктів в один. При об’єднанні власника і підпорядкованого об'єкта створюється новий тип запису, в якому підпорядкований об’єкт виступає як агрегат типу залису-власника. Отже, зв'язок ПВ ліквідується, а зв'язок ВПВ перетворюється на ВП. Це перетворення через злиття двох об'єктів в один можливе тоді, коли підпорядкований об'єкт не бере участі в інших наборах.
Перетворення 2. Згідно з правилами побудови сіткових моделей кожний набір не може мати більш як одного власника в одному й тому самому наборі. Тому наступним кроком відображення є усунення багатозначного володіння. Усі зв'язки типу «багато до багатьох» (Б:Б) не можуть бути реалізовані в явному вигляді. їх моделюють так, як показано на рисунку.
А
В
С
Посилання
на А
Основне перетворення при цьому — перехід до дворівневих структур. Це перетворення можна виконати за допомогою двох варіантів
Варіант 1 полягає в перенесенні всіх проміжних рівнів на перший рівень ієрархії.
А
В
Вказівка
на С
Варіант 2 полягає у використанні кодованих записів. На рисунку екземпляр запису CD — це запис типу С або запис типу D. Для того щоб відрізнити запис типу С від запису типу D, до складу таких записів уводять додаткове поле, яке є кодом, що вказує на тип запису, тому ці записи називаються кодованими.
Если не удалось найти и скачать презентацию, Вы можете заказать его на нашем сайте. Мы постараемся найти нужный Вам материал и отправим по электронной почте. Не стесняйтесь обращаться к нам, если у вас возникли вопросы или пожелания:
Email: Нажмите что бы посмотреть