5.3.3 Поняття універсального відношення
Припустимо, що проектування бази даних "Живлення" починається з виявлення атрибутів і підбору даних, зразок яких (частина блюд виготовлених і реалізованих 1/9/94 р.) показаний на рис. 3.2.
Цей варіант таблиці "Живлення" не є відношенням, оскільки більшість її рядків не атомарни. Атомарними є лише значення полів Блюдо, Вигляд, Рецепт (хоча він і великий), Порцій і Дата_р решта полів таблиці рис. 3.2- же множинна. Для додання таким даним форми відношення необхідно реконструювати таблицю. Найпростіше це зробити за допомогою простого процесу вставки, результат якої показаний на рис. 3.3. Проте таке перетворення приводить до виникнення великого об'єму надмірних даних.
Таблиця на рис. 3.3 є екземпляром коректного відношення. Його називають універсальним відношенням проектованої БД. У одне універсальне відношення включаються всі атрибути, що представляють інтерес, і воно може містити всі дані, які передбачається розміщувати в БД в майбутньому. Для малих БД (що включають не більше 15 атрибутів) універсальне відношення може використовуватися як відправна крапка при проектуванні БД.
При використанні універсального відношення виникає декілька проблем:
Надмірність. Дані практично всіх стовпців багато разів повторюються. Повторюються і деякі набори даних (Блюдо-Вид-рецепт, Продукт-Калорійність, Поставщик-Город-страна). Небажане повторення рецептів, деякі з яких набагато більше рецепту "Лобіо". І вже зовсім погано, що всі дані про блюдо (включаючи рецепт) повторюються кожного разу, коли це блюдо включається в меню.
Потенційна суперечність (аномалії оновлення). Унаслідок надмірності можна відновити адресу постачальника в одному рядку, залишаючи його незмінним в інших. Якщо постачальник каві повідомив про свій переїзд до Харбіну і був оновлений рядок з продуктом кави, то у постачальника "Хуанхе" з'являється дві адреси, один з яких не актуальний. Отже, при оновленнях необхідно проглядати всю таблицю для знаходження і зміни всіх відповідних рядків.
Аномалії включення. У БД не може бути записаний новий постачальник ("Нярінга", Вільнюс, Литва), якщо продукт (Огірки), що поставляється ним, не використовується ні в одному блюді. Можна, звичайно, помістити невизначені значення в стовпці Блюдо, Вигляд, Порцій і Вес (г) для цього постачальника. Але якщо з'явиться блюдо, в якому використовується цей продукт, чи не забудемо ми видалити рядок з невизначеними значеннями?
По аналогічних причинах не можна ввести і новий продукт (наприклад, Баклажани), який пропонує існуючий постачальник (наприклад, "Полісся"). А як ввести нове блюдо, якщо в нім використовується новий продукт (Краби)?
Аномалії видалення. Зворотна проблема виникає при необхідності видалення всіх продуктів, що поставляються даним постачальником або всіх блюд, що використовують ці продукти. При таких видаленнях будуть втрачені відомості про такого постачальника.
Багато проблем цього прикладу зникнуть, якщо виділити в окремі таблиці відомості про блюда, рецепти, витрату блюд, продукти і їх постачальників, а також створити таблиці, що пов'язують, "Склад" і "Постачання".
Блюдо | Вид | Рецепт | Порций | Дата Р | Продукт | Калор. | Вес (г) | Поставщик | Город | Страна | Вес (кг) | Цена ($) | Дата П |
Лобио | Закуска | Лом. | 158 | 1/9/94 | Фасоль | 3070 | 200 | "Хуанхэ" | Пекин | Китай | 250 | 0.37 | 24/8/94 |
|
|
|
|
| Лук | 450 | 40 | "Наталка" | Киев | Украина | 100 | 0.52 | 27/8/94 |
|
|
|
|
| Масло | 7420 | 30 | "Лайма" | Рига | Латвия | 70 | 1.55 | 30/8/94 |
|
|
|
|
| Зелень | 180 | 10 | "Даугава" | Рига | Латвия | 15 | 0.99 | 30/8/94 |
Харчо | Суп | ... | 144 | 1/9/94 | Мясо | 1660 | 80 | "Наталка" | Киев | Украина | 100 | 2.18 | 27/8/94 |
|
|
|
|
| Лук | 450 | 30 | "Наталка" | Киев | Украина | 100 | 0.52 | 27/8/94 |
|
|
|
|
| Томаты | 240 | 40 | "Полесье" | Киев | Украина | 120 | 0.45 | 27/8/94 |
|
|
|
|
| Рис | 3340 | 50 | "Хуанхэ" | Пекин | Китай | 75 | 0.44 | 24/8/94 |
|
|
|
|
| Масло | 7420 | 15 | "Полесье" | Киев | Украина | 50 | 1.62 | 27/8/94 |
|
|
|
|
| Зелень | 180 | 15 | "Наталка" | Киев | Украина | 10 | 0.88 | 27/8/94 |
Шашлык | Горячее | ... | 207 | 1/9/94 | Мясо | 1660 | 180 | "Юрмала" | Рига | Латвия | 200 | 2.05 | 30/8/94 |
|
|
|
|
| Лук | 450 | 40 | "Полесье" | Киев | Украина | 50 | 0.61 | 27/8/94 |
|
|
|
|
| Томаты | 240 | 100 | "Полесье" | Киев | Украина | 120 | 0.45 | 27/8/94 |
|
|
|
|
| Зелень | 180 | 20 | "Даугава" | Рига | Латвия | 15 | 0.99 | 30/8/94 |
Кофе | Десерт | ... | 235 | 1/9/94 | Кофе | 2750 | 8 | "Хуанхэ" | Пекин | Китай | 40 | 2.87 | 24/8/94 |
Рис. 3.2 Дані, необхідні для створення бази даних "Живлення"
Блюдо | Вид | Рецепт | Порций | Дата Р | Продукт | Калор. | Вес (г) | Поставщик | Город | Страна | Вес (кг) | Цена ($) | Дата П |
Лобио | Закуска | Лом. | 158 | 1/9/94 | Фасоль | 3070 | 200 | "Хуанхэ" | Пекин | Китай | 250 | 0.37 | 24/8/94 |
Лобио | Закуска | Лом | 158 | 1/9/94 | Лук | 450 | 40 | "Наталка" | Киев | Украина | 100 | 0.52 | 27/8/94 |
Лобио | Закуска | Лом | 158 | 1/9/94 | Масло | 7420 | 30 | "Лайма" | Рига | Латвия | 70 | 1.55 | 30/8/94 |
Лобио | Закуска | Лом | 158 | 1/9/94 | Зелень | 180 | 10 | "Даугава" | Рига | Латвия | 15 | 0.99 | 30/8/94 |
Харчо | Суп | Лом | 144 | 1/9/94 | Мясо | 1660 | 80 | "Наталка" | Киев | Украина | 100 | 2.18 | 27/8/94 |
Харчо | Суп | Лом | 144 | 1/9/94 | Лук | 450 | 30 | "Наталка" | Киев | Украина | 100 | 0.52 | 27/8/94 |
Харчо | Суп | Лом | 144 | 1/9/94 | Томаты | 240 | 40 | "Полесье" | Киев | Украина | 120 | 0.45 | 27/8/94 |
Харчо | Суп | Лом | 144 | 1/9/94 | Рис | 3340 | 50 | "Хуанхэ" | Пекин | Китай | 75 | 0.44 | 24/8/94 |
Харчо | Суп | Лом | 144 | 1/9/94 | Масло | 7420 | 15 | "Полесье" | Киев | Украина | 50 | 1.62 | 27/8/94 |
Харчо | Суп | Лом | 144 | 1/9/94 | Зелень | 180 | 15 | "Наталка" | Киев | Украина | 10 | 0.88 | 27/8/94 |
Шашлык | Горячее | Лом | 207 | 1/9/94 | Мясо | 1660 | 180 | "Юрмала" | Рига | Латвия | 200 | 2.05 | 30/8/94 |
Шашлык | Горячее | Лом | 207 | 1/9/94 | Лук | 450 | 40 | "Полесье" | Киев | Украина | 50 | 0.61 | 27/8/94 |
Шашлык | Горячее | Лом | 207 | 1/9/94 | Томаты | 240 | 100 | "Полесье" | Киев | Украина | 120 | 0.45 | 27/8/94 |
Шашлык | Горячее | Лом | 207 | 1/9/94 | Зелень | 180 | 20 | "Даугава" | Рига | Латвия | 15 | 0.99 | 30/8/94 |
Кофе | Десерт | Лом | 235 | 1/9/94 | Кофе | 2750 | 8 | "Хуанхэ" | Пекин | Китай | 40 | 2.87 | 24/8/94 |
Рис.5.3.3 Універсальне відношення "Живлення"
- Іі. Електронні обчислювальні машини (еом)
- 2.1. Класифікація еом за розміром
- 2.2. Класифікація персональних еом
- 2.3. Класифікація пк за сферою застосування
- Ііі. Персональні комп’ютери. Особливості їх складу, конструкції і конфігурації.
- Питання для самоперевірки
- 1.3 Призначення, конструкція і характеристики пристроїв персональних комп’ютерів: системний блок, блок живлення, мікропроцесор, материнська плата, оперативна пам’ять
- Питання для самоперевірки
- 1.4 Призначення, конструкція і характеристики пристроїв персональних комп’ютерів: накопичувачі, адаптери
- 1.5 Призначення, конструкція і характеристики пристроїв персональних комп’ютерів: звукові карти, монітор, клавіатура
- 1.6 Призначення, конструкція і характеристики пристроїв персональних комп’ютерів: принтер, модеми, сканери, джерела безперебійного живлення
- Artec viewstation as6e
- Artec viewstation at12 scsi
- Artec viewscan a2000d
- Boeder compact colour 1200 (65137)
- 2. Операційна система windows xp. Основні поняття на принципи роботи у системі.
- 2.1 Історія Windows
- 2.2 Файлова система та структура.
- Запитання для контролю.
- 2.3 Основні принципи роботи з системою
- 2.4 Робота з файлами та папками.
- Переміщення та копіювання папок та файлів
- Пошук файлів та папок
- Приклад контрольного завдання за темою Основи роботи в ос Windows xp
- 3. Введение в microsoft office.
- 3.1 Microsoft word.
- 3.1.1 Запуск і ознайомлення з пакетом
- 3.1.1.1 Введення в Microsoft Word.
- 3.1.1.2 Меню і панелі інструментів Word.
- 3.1.1.4 Початок роботи з документом.
- 3.1.2. Налаштування параметрів сторінки
- 3.1.2.1 Завдання режиму сторінки
- 3.1.2.2Налаштування масштабу документа
- 3.1.2.3 Попередній перегляд файлу
- 3.1.2.4. Друк документа
- 3.1.2.5. Установка параметрів сторінки
- 3.1.2.6 Додавання колонтитулів
- 3.1.3. Набір і редагування тексту. Шрифт.
- 3.1.3.1 Налаштування шрифтів
- 3.1.3.2 Робота з шрифтами
- 3.1.3.3 Вставка символу в документ
- 3.1.3.4. Виділення фрагмента тексту
- 3.1.4. Набір і редагування тексту. Абзац.
- 3.1.4.1. Завдання вирівнювання і інтервалів
- 3.1.4.2. Завдання відступів
- 3.1.4.3. Оформлення тексту в декілька колонок
- 3.1.4.4. Створення списків
- 3.1.4.5. Вставка розриву сторінки або розділу
- 3.1.4.6. Відміна і повторення виконаних дій.
- 3.1.4.7. Копіювання і переміщення інформації.
- 3.1.5. Вставка об'єктів.
- 3.1.5.1 Створення простих формул
- 3.1.5.2. Запис формул за допомогою редактора формул
- 3.1.5.3. Вставка об'єктів Wordart.
- 3.1.5.4. Робота з ClipArt
- 3.1.5.5. Створення графічних об'єктів.
- 3.1.6. Робота з таблицями.
- 3.1.6.1 Створення таблиці.
- 3.1.6.2 Основні комбінації клавіш для роботи з таблицями.
- 3.1.6.3 Зміна таблиці.
- 3.1.6.4 Форматування таблиці
- 3.1.6.5. Написання формул і побудова діаграм.
- 3.2 Текстовий редактор Open Office org Writer
- 3.2.1 Робота з документами
- Комбінації клавіш для переміщення в межах тексту
- Питання для самоперевірки
- 3.2.2 Форматування тексту
- 3.2.3 Створення таблиць та діаграм
- 3.2.4 Вставка об’єктів у документ
- Питання для самоперевірки
- 3.2.5 Призначення стилів і їх використання в документах
- Питання для самоперевірки
- 3.2.6 Засоби підготовки і представлення презентацій
- 4. Електронні таблиці (ms Excel та oo Calc)
- 4.1.Загальні положення
- 4.2.Типи даних, введення та форматування даних у ет
- 4.3. Редагування даних в ет
- 4.4. Функції та обчислення у ет
- 4.5. Організація графічної інформації
- 4.6. Робота з базами даних (списками)
- 4.7. Аналіз даних
- 5. Загальні поняття баз даних.
- 5.1 Бази даних
- 5.1.1 Поняття бази даних і субд
- 5.1.2 Ієрархічна модель даних
- 5.1.3 Мережева модель даних
- 5.1.4 Реляційна модель даних
- 5.1.5 Рівні моделі даних.
- 5.2. Інфологичеська модель даних "суть-зв'язок"
- 5.2.1 Поняття, використовувані в інфологичному моделюванні.
- 5.2.2 Основні класи суті.
- 5.2.3 Er- діаграми і мова інфологичеського моделювання (яім)
- 5.2.4 Види зв'язків
- 5.3. Реляційна база даних
- 5.3.1 Основні поняття, використовувані в реляційних базах даних
- 5.3.2 Правила побудови реляційних баз даних
- 5.3.3 Поняття універсального відношення
- 5.3.4 Нормалізація
- 5.3.5 Процедура проектування
- 5.4. Microsoft Access. Создание таблиц
- 5.4.1ЗапускпрограммыMicrosoft Access
- 5.4.2 Створення таблиць
- 5.4.2.1 Режим таблиць
- 5.4.2.2 Режим конструктора
- 5.4.2.3 Майстер таблиць
- 5.4.3. Види представлення таблиці
- 5.4.4. Редагування проекту таблиці
- 5.5. Визначення зв'язків між таблицями
- 5.6. Створення запитів
- 5.6.1 Створення запитів в режимі конструктора
- 5.6.2 Приклади запитів
- 5.6.3 Створення запитів в режимі sql
- 5.6.4 Інструкції sql
- 5.7. Access. Створення форм
- 5.7.1 Майстер форм.
- 5.7.2 Режим Конструктора
- 5.7.3 Заповнення Форми в режимі конструктора
- 5.7.4 Виклик однієї форми з іншої
- 5.7.5 Додавання в Примітку форми поточної дати і час
- 5.8. Access. Створення звітів
- 5.8.1 Кроки створення звіту в режимі Майстра звітів
- 5.8.2 Створення звітів в режимі Конструктора
- 6. Комп'ютерні мережі
- 6.1. Введене
- 6.2. Класифікації мереж
- 6.2.1. Класифікація за розміром охопленої території :
- 6.2.2. Класифікація за типом функціональної взаємодії
- 6.2.3. Класифікація за типом мережевої топології.
- 6.3. Огляд мережевого устаткування.
- 6.3.1 Крайове устаткування лінії зв'язку.
- 6.3.2 Проміжне мережеве устаткування.
- 6.3.3 Комутатор
- 6.3.4 Маршрутизатор
- 6.3.5 Шлюзи
- 6.3.6 Кабельні системи
- 6.3.7 Безпровідні технології
- 6.4.Вимоги, що пред'являються до мереж
- 6.5. Глобальна мережа Internet (інтернет). Www.
- Ip -телефония.
- 7. Основи алгоритмізації і програмування
- 7.1. Стадії рішення завдань на комп'ютері
- 7.2. Алгоритми.
- Команди шкільного ам
- Кін Базові структури алгоритмів.
- Лінійні алгоритми
- Розвилка
- Вкладені цикли
- Приклад вкладених циклів «поки»
- Програмний спосіб запису алгоритмів
- Рівень мови програмування
- Логічні вирази
- Література