БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 1. Інформаційні системи
Означення База даних (БД) – це сховище даних про деяку предметну область, організоване у вигляді спеціальної структури. Важливо: дані про деяку область (не про все) впорядковані Система керування базою даних (СКБД) – це програмне забезпечення для роботи з БД. Функції: пошук інформації в БД виконання нескладних розрахунків виведення звітів на друк редагування БД Інформаційна система – це БД + СКБД.
Типи інформаційних систем локальні ІС БД і СКБД знаходяться на одному комп'ютері. файл-серверні БД знаходиться на сервері мережі (файловому сервері), а СКБД на комп'ютері користувача. клієнт-серверні БД і основна СКБД знаходяться на сервері, СКБД на робочій станції посилає запит і виводить на екран результат.
Локальні ІС БД СКБД автономність (незалежність) 1)з БД працює тільки одна людина 2)складно обновляти при великій кількості користувачів 3)практично неможливо стикувати зміни, які вносять різні користувачі
Файл-серверні ІС БД СКБД декілька людей працюють з одною базою 1)основну роботу виконують робочі станції (РС), вони повинні бути потужними 2)для пошуку рядка на РС копіюється вся БД – навантаження на мережу 3)слабкий захист від злому (тільки на РС) 4)проблеми при одночасній зміні з різних РС
Клієнт-серверні ІС БД СКБД-клієнт 1)основну роботу виконує сервер, робочі станції можуть бути малопотужними 2)легше модернізується (тільки сервер) 3)по мережі ідуть тільки потрібні дані 4)захист і права доступу встановлюються на сервері (складніше пошкодити) 5)розділення доступу (черга завдань) запит на SQL відповідь СКБД-сервер: MS SQL Server Oracle MySQL Interbase SyBase SQL (Structured Query Language) – мова структурних запитів 1)складність налаштування 2)висока вартість ПЗ (тисячі $)
БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 2. Бази даних © К.Ю. Поляков, 2007 Переклад Р.М. Васильчик
Типи баз даних табличні БД дані у вигляді однієї таблиці мережеві БД набір вузлів, в яких кожен може бути зв'язаний з кожним. ієрархічні БД у вигляді багаторівневої структури реляційні БД (99,9%) набір взаємопов'язаних таблиць
Табличні БД ПрізвищеІм'яАдресаТелефон ПетровВасяШевченка пл., б. 32, кв ІвановПетроФранка вул., б. 25, кв Модель – картотека Приклади: записна книжка каталог в бібліотеці Петров Вася Шевченка пл., б. 32, кв записи 1)найпростіша структура 2)всі інші типи БД використовують таблиці в багатьох випадках – дублювання даних: поля Т.Г. ШевченкоКобзар540 ст. Т.Г. ШевченкоГайдамаки45 ст.
Табличні БД 1.Кількість полів визначається розробником і не може змінюватися користувачем. 2.Будь-які поля повинні мати унікальне ім'я. 3.Поля можуть мати різний тип: рядок символів (довжиною до 255 символів) дійсне число (з дробовою частиною) ціле число грошова сума дата, час, дата і час логічне поле (істина або хибність, так або ні) багатосторінковий текст (МЕМО) малюнок, звук або інший об'єкт (об'єкт OLE) 4.Поля можуть бути обов'язковими для заповнення або ні. 5.Таблиці можуть містити скільки завгодно записів (ця кількість обмежується тільки об'ємом диску); записи можна добавляти, вилучати, редагувати, сортувати, шукати.
Ключове поле (ключ таблиці) Ключове поле (ключ) – це поле (або комбінація полів), які однозначно визначають запис. В таблиці не може бути двох записів з однаковими значеннями ключа. Чи можуть дані поля бути ключем? прізвище ім'я номер паспорта номер будинку реєстраційний номер автомобіля пункт проживання дата виконаних робіт марка пральної машини ?
Мережеві БД Мережева БД – це набір вузлів, в яких кожен може бути зв'язаний з кожним. БГ А В найповніше відображає структуру деяких задач (наприклад, мережеве планування в економіці) 1)складно зберігати і шукати інформацію в усіх зв'язках 2)заплутаність структури Можна зберігати у вигляді таблиці, але з дублюванням даних! ! !
Ієрархічна БД Ієрархічна БД – це набір даних у вигляді багаторівневої структури. Прайс-лист: Продавець (рівень 1) Товар (рівень 2) Модель (рівень 4) Ціна (рівень 5) Виробник (рівень 3) $306 $312 S93 X93B Sony Phillips Samsung Монітори Принтери Іван
Ієрархічна БД Перетворення в табличну форму: ПродавецьТоварВиробникМодельЦіна ІванМоніторSonyS93$306 ІванМоніторSonyX93B$312 ІваннМоніторPhillips190 B5 CG$318 ІванМоніторSamsungSyncMaster 193P$452 … 1)дублювання даних 2)при зміні адреси фірми потрібно міняти її в усіх рядках 3)немає захисту від помилок введених оператором (Іван – Іванн), краще було б вибрати із списку
БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 3. Реляційні бази даних © К.Ю. Поляков, 2007 Переклад Р.М. Васильчик
Реляційні БД 1970-і рр. Е. Кодд, англ. relation – відношення. Реляційна база даних – це набір простих таблиць, між якими встановлені зв'язки (відношення) з допомогою числових кодів. Продавці Код Назва Адреса Телефон Сайт Виробник Код Назва Країна Сайт Моделі Код Назва Код виробника Товари Код Назва Прайс-лист Код запису Код продавця Код виробника Код товару Код моделі Ціна
Реляційні БД 1)немає дублювання інформації; 2)при зміні адреси фірми, достатньо змінити її тільки в таблиці Продавці; 3)захист від неправильного введення: можна вибирати тільки фірму, яка заздалегідь введена в таблицю Продавці; 4)механізм транзакції: будь-які зміни вносяться в базу тільки тоді, коли вони повністю завершені. 1)складність структури (не більше таблиць); 2)при пошуку потрібно звертатися до декількох таблиць; 3)потрібно підтримувати цілісність: при вилученні фірми продавця потрібно вилучати всі зв'язані записи з всіх таблиць (в СКБД – автоматично, каскадні вилучення).
Зв'язки між таблицями Один до одного («1-1») – одному запису в першій таблиці відповідає тільки один запис в другій таблиці. Примітка: виділення часто використовуваних даних. КодПрізвищеІм'я 1ІвановКузьма 2ПетровВасиль … КодРік народженняАдреса 11992Шевченка, б.20, кв Франка вул., б. 30, кв. 18 … 1 1 Один до багатьох («1- ») – одному запису в першій таблиці відповідає декілька записів в другій. КодНазва 1Монітор 2Вінчестер … КодКод товаруЦіна … 1 товари прайс- лист
Звязок між таблицями Багато до багатьох (« - ») – одному запису в першій таблиці відповідає декілька записів в другій, і навпаки. КодПрізвище 1Іванов 2Петров … КодНазва 1Історія 2Географія 3Біологія … Реалізація – через третю таблицю і два зв'язки «1- ». КодПрізвище 1Іванов 2Петров … КодНазва 1Історія 2Географія 3Біологія … Код Код вчителя Код предмету Клас 1119-А 2128-Б 3237-В … розклад вчителі предмети 1 1
Нормалізація бази даних Нормалізація – це розробка такої структури БД, в які немає надлишкових даних і зв'язків. Основні принципи: Будь-яке поле повинно бути неподільним. Прізвище і ім'я Іванов Петро Петров Іван … ПрізвищеІм'я ІвановПетро ПетровІван … Не повинно бути полів, в яких позначені різні види одного і того ж, наприклад, товарів. РікБананиКіві … Рік Код товару Кількість … КодНазва 1Банани 2Ківі … 1
Нормалізація бази даних Основні принципи: Будь-яке поле повинно залежати тільки від ключа (ключ – це поле або комбінація полів, однозначно визначає запис). КодНазваЦіна 1Монітор1800 грн. 2Вінчестер2200 грн. … Не повинно бути полів, які можуть бути знайдені з допомогою інших. КодТовар Ціна за тонну Кількість, тонн Вартість 1Банани Киви … товари залежить не тільки від назви товару! прайс-лист
Пошук в базі даних Лінійний пошук – це перебір всі записів до тих пір, поки не буде знайдений потрібний. КодПрізвище 1Сидоров 2Вєтров … 1024Помаранський Іванов? 1024 порівняння! дані не потрібно попередньо підготовлювати низька швидкість пошуку
Двійковий пошук 1.Розділити область пошуку на дві рівні частини. 2.Визначити, в якій половині знаходиться потрібний об'єкт. 3.Перейти до кроку 1 для цієї половини. 4.Повторювати кроки 1-3 поки об'єкт не буде зловлений. 1.Розділити область пошуку на дві рівні частини. 2.Визначити, в якій половині знаходиться потрібний об'єкт. 3.Перейти до кроку 1 для цієї половини. 4.Повторювати кроки 1-3 поки об'єкт не буде зловлений.
Пошук в базі даних 1Андрєєв 2Борсуков … 512Коваль … 1023Юр'єв 1024Яшин Двійковий пошук в БД – потребує попереднього сортування. Іванов? 1Андрєєв … 255Жаров … 512Коваль … 1024Яшин … 255Жаров … 383Ігорів … 512Коваль … Скільки порівнянь? ? ? 1)записи потрібно відсортувати по відповідному полю; 2)можна використовувати тільки для одного поля. швидкий пошук 11 порівнянь!
Пошук по індексах Індекс – це допоміжна таблиця, яка призначена для швидкого пошуку в основній таблиці по обраному стовпчику. Таблиця НомерДатаТоварКількість Ківі Банани Апельсини10 Індекси: по даті НомерДата по товарупо кількості НомерТовар 3Апельсини 2Банани 1Ківі НомерКоличество
Пошук по індексах Алгоритм пошуку: 1)двійковий пошук по індексу – знайти номер потрібних записів; 2)вибрати ці записи по номерам із основної таблиці. 1)індекси займають місце на диску; 2)при зміні таблиці потрібно перебудовувати всі індекси (в СКБД – автоматично). двійковий пошук по всім стовпчикам, для яких побудовані індекси
БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 4. Бази даних Access. Робота з таблицями © К.Ю. Поляков, 2007 Переклад Р.М. Васильчик
Бази даних Access (Microsoft Office) Розширення: *.mdb, один файл Склад: таблиці; форми – діалогові вікна для введення і редагування даних; запити – звернення до бази даних для вибору потрібної інформації або зміни бази; звіти – документи для виведення на друк; макроси – засоби автоматизації роботи; модулі – додаткові процедури на мові Visual Basic.
Початок роботи Пуск – Програми – Microsoft Office – Microsoft Access 2003
Сервіс – Схема даних таблиця ключове поле зв'язок «1- » Усунути зв'язок: ЛКМ + Delete. Створити зв'язок: перетягнути потрібне поле на відповідне поле іншої таблиці.
Робота з таблицями Таблиці – Замовлення – або два рази клікаємо ЛКМ
Робота з таблицями поля записи поточний запис область виділення новий запис на 1-й запис попередній запис номер поточного запису наступний запис останній запис перейти на новий запис всього записів поточне поле
Сортування і пошук Сортування по поточному полю (стовпчику): по зростанню (в алфавітному порядку) по спаданню (в зворотному алфавітному порядку) Пошук і заміна: поточне поле або всі поля повністю, з будь- якою частиною, з початку всі, вверх, вниз
Фільтрація Фільтрація – це відбір записів, які задовольняють деяку умову (фільтр). Решта записів тимчасово скриваються, поки фільт не буде знятий. Фільтр по виділеному 1.Клікнути в потрібній комірці або виділити частину тексту. 2.Клікнути по кнопці. 3.Зняти фільтр.
Фільтрація Складені умови Одночасно (операція І) Одночасно (операція І) Починається з С нова умова, зв'язана через АБО Записи – Фільтр – Змінити фільтр Повний варіант: Записи – Фільтр – Розширений фільтр можна переставляти стовпчики можна виводити не всі стовпчики можна встановлювати порядок сортування Точне співпадання
Службові операції Сервіс – Службові програми: Перетворити базу даних в формат Access-97 в формат Access-2000 Стиснути і відновити базу даних (фізично вилучити зайві записи) Резервна копія бази даних Встановлення пароля: Сервіс – Захист – Задати пароль бази даних
БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 5. Проектування таблиць © К.Ю. Поляков, 2007 Переклад Р.М. Васильчик
Створення таблиць введення даних і назв полів (режим таблиця); конструктор – ручне налаштування; майстер таблиць – створення таблиць стандартних типів (Товари, Клієнти, Співробітники, …); імпорт таблиць – завантаження даних із інших джерел (БД інших форматів, Excel, текстові файли, …).
Створення таблиць Введення данихМайстер Імпорт з інших БД Access з БД інших форматів (*.db, *.dbf) з таблиць Excel и документів XML з текстових БД (CSV – comma separated values)
Конструктор таблиць перейти в конструктор перейти в режим таблиці
Конструктор таблиць тип поля (вибір з списку) властивості поточного поля ключ поточне поле
Властивості полів Розмір поля: байт, ціле, дійсне, … Формат поля: як виводити на екран. Маска введення: шаблон (введення телефону). Підпис: як називається стовпчик при виведенні на екран (можна використовувати лапки, знаки і т.д. «Населення, млн. чол.») Значення по замовчуванню (вписується автоматично). Умови на значення: захист від помилок введення («>18»). Повідомлення про помилку («Вік повинен бути більше 18 років!») Обов'язкові поля (так/ні) Індексовані поля (так/ні)
Операції з полями зробити поле ключовим (скасувати…) добавити поле вище поточного вилучити поточне поле (або всі виділені) індекси поле таблиці (вибір з списку) поле таблиці (вибір з списку) Primary Key: ключ таблиці Primary Key: ключ таблиці назва індексу
Підстановки Мета: створити захист від помилок введення. Розв'язання: вибір з списку = поле підстановки Варіанти: заданий список («так» або «ні», «Ч» або «Ж») з другої таблиці (наприклад, вибір назви фірми) Як зробити:
Майстер підстановок
БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 6. Форми © К.Ю. Поляков, 2007 Переклад Р.М. Васильчик
Форми Форма – це діалогове вікно для: перегляду і редагування даних введення нових записів керування процесом роботи (кнопки) виведення додаткової інформації Створення форм: джерело даних
Створення форм Конструктор – повністю вручну. Майстер форм – режим «запитання – відповідь». Автоформа в стовпчик: Автоформа стрічкова: Автоформа таблична: Діаграма:
Конструктор форм перейти в конструктор перейти в режим форми область виділення кнопки переходу
Конструктор форм вибраний елемент заголовок форми область даних примітки форми зміна розмірів
Властивості форми Вікно властивостей Правка – Виділити форму область виділення Макет кнопки переходу Дані Джерело – таблиця або запит Фільтр – умова відбору записів Сортування Події (призначення макросів) натискання на клавішу, дії мишкою, … відкриття, закриття, зміна запису, …
Зв'язані елементи надпис (текст можна міняти) поле (назва поля таблиці) маркери (зміна розмірів) незалежне переміщення клікнути всередині, щоб змінити текст клікнути на рамці, щоб виділити елемент
Властивості елементів Панель форматування вибраний елемент назва шрифту розмір шрифту жирний, курсив, підкреслений вирівнювання колір фону колір тексту колір рамки товщина рамки стиль Стиль оформлення: нормальний, припіднятий, втоплений, вдавлений, с тінню, рельєфний Виділення елементів: ЛКМ на рамці елемента + Shift = виділення декількох елементів
Властивості елементів Вікно властивостей Макет: розміри оформлення Дані: Дані – назва поля Маска введення – шаблон (для телефону) Значення по замовчуванню Умова по значенню Повідомлення про помилку Події дії користувача (клавіатура, миша) зміна даних ПКМ – Властивості
Добавлення нових елементів Вивести (приховати) панель елементів вибір об'єктів майстри надпис поле (інформація з бази даних малюнок незалежний об'єкт (наприклад, діаграма Excel) елементи інтерфейсу зв'язаний об'єкт (який зберігається в БД) розрив сторінки підлегла форма інші елементи
БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 7. Макроси © К.Ю. Поляков, 2007 Переклад Р.М. Васильчик
Макроси Макрос – це набір макрокоманд. Макрокоманда описує дії, які потрібно виконати: відкриття і закриття таблиць, звітів, форм виконання запитів встановлення значень полів пошук даних керування виведенням на екран друк даних повідомлення користувачу запуск інших програм Події (для запуску макросу) дії користувача (клавіатура, миша) внутрішні події (відкриття і закриття форми, зміна запису і т.д.)
Простий макрос Конструктор
Макроси Відлагодження макросу перейти в конструктор Запуск – По крокам запустити на виконання Використання макросів AutoExec – виконується автоматично при відкриванні бази призначення подій вибрати ім'я макросу з списку
Макроси Групи макросів Вигляд – Імена макросів Запуск Макрос1: QQQ Макрос1: MMM Макрос1 тільки перша група Умови виконання Вигляд – Умова або
БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 8. Запити © К.Ю. Поляков, 2007 Переклад Р.М. Васильчик
Запити «Ну і запити у вас!» - сказала база даних и «зависла». (Фольклор) Запит – це звернення до СКБД для виконання яких-небудь операцій з даними. Типи запитів: вибірка створення таблиці обновлення (зміна даних) добавлення записів вилучення записів …
Запит і фільтрування В запиті можна: відбирати інформацію з декількох зв'язаних таблиць використовувати складні умови відбору користувач може сам ввести параметри (суму грошей) добавити обчислювані поля виконати підсумкові розрахунки
Створення запитів
Майстер запитів
Запуск запиту
Конструктор перейти в конструктор перейти в режим таблиці
Конструктор таблиця (ПКМ – Добавити таблицю) таблиця (ПКМ – Добавити таблицю) перетягнути ЛКМ всі поля по зростанню по спаданню відсутнє по зростанню по спаданню відсутнє фільтр
Робота з стовпчиками виділити (ЛКМ) ПКМ: вирізати копіювати вставити властивості ПКМ: вирізати копіювати вставити властивості перетягнути (ЛКМ)
Умови відбору Співпадання Нерівність Шаблон * будь-яка кількість, будь-яких символів ? один будь-який символ # будь-яка цифра
Побудова виразів Forms – форми Reports – звіти Функції: 1) вбудовані; 2) функції користувача (VB) Константи: порожня стрічка, Істина, Хибність Оператори: + - * / = = <> Not And Or Xor Загальні вирази – час, дата, нумерація сторінок ПКМ
Всі дані, які можна обчислити не повинні зберігатися в таблиці ! ! Обчислювані поля ввести Ціна*Кількість Вираз1: [Ціна]*[Кількість] замінити Вираз1 на Сума ввести Ціна*Кількість Вираз1: [Ціна]*[Кількість] замінити Вираз1 на Сума ввести Year(Дата) Вираз1: Year([Дата]) замінити Вираз1 на Рік ввести Year(Дата) Вираз1: Year([Дата]) замінити Вираз1 на Рік або ПКМ - Побудувати
Запити з параметрами Задача: вводити числові дані для фільтра не в конструкторі, а при виконанні запиту. Приклад: «Якою сумою Ви розраховуєте?» Будь-який незалежний рядок викликає запит
Підсумковий запит Конструктор Таблиця Підсумковий запит Групові операції Групування Sum – сума
Підсумковий запит (майстер) ЛКМ
Перехресний запит Таблиці Перехресний запит
Конструктор: Запит – Перехресний Заголовок рядка Заголовок стовпця Значення Майстер – не дозволяє вибирати інформацію з декількох таблиць (тільки через додатковий запит).
Запит на оновлення (зміну) Задача: в усіх записах, які відносяться до 2007 року, замінити дату в полі Дата на сьогоднішнє число. Розв'язання: запит, який відбирає всі потрібні записи резервна копія таблиці (Копіювати – Вставити) меню Запит – Оновлення в рядку Оновлення ввести нове значення поля: виконати запит Оновлення
Інші види запитів Вилучення: запит на вибірку потрібних записів резервна копія таблиці Запит – Вилучення виконати запит Створення таблиці: Запит – Створення таблиці Добавлення даних в підсумкову таблицю: Запит – Добавлення Повторні записи: Запит – Створити – Повторний запис Записи без підлеглих: Запит – Створити – Записи без підлеглих
БАЗИ ДАНИХ. ІНФОРМАЦІЙНІ СИСТЕМИ Тема 9. Звіти © К.Ю. Поляков, 2007 Переклад Р.М. Васильчик
Створення звітів Звіт – це документ, який містить інформацію з бази даних і призначений для виведення на друк. Тільки одне джерело! ! ! Джерело: таблиця або запит
Автозвіти Автозвіт в стовпчикАвтозвіт стрічковий
Режим перегляду звіту 2 x ЛКМ
Режим перегляду звіту – перейти в конструктор – друк – масштаб (переключення режиму) – одна сторінка – дві сторінки – декілька сторінок – масштаб у відсотках – закрити вікно перегляду – налаштування (поля, формат папір)
Конструктор звітів Заголовок звіту – один раз на початку звіту. Верхній колонтитул – на початку кожної сторінки. Область даних – інформація з БД. Нижній колонтитул – в кінці кожної сторінки. Примітки звіту – один раз в кінці звіту. =Сторінка " & [Page] & " з " & [Pages] =Now()
Редагування звітів – вивести (приховати) панель елементів – властивості вибраного елемента Аналогічно, як в конструкторі форм: ЛКМ – виділити елемент
Звіти з групуванням групування по посадах загальна зарплата
Звіти з групуванням (крок 1) Створення запиту, який включає всі дані: & - з'єднання символьних рядків поля таблиць
Звіти з групуванням (крок 2) Використання майстра звітів: Підсумкові дані
Звіти з групуванням (конструктор) Заголовок групи Примітки групи
Звіти з групуванням (конструктор) сортування і групування