
- •Вступ до баз даних. Загальна характеристика основних понять
- •1.1. Розвиток основних понять представлення даних
- •Лекція 6
- •Друга стадія концептуального проектування бд. (Моделі даних субд. Представлення концептуальної моделі засобами моделі даних субд)
- •6.1. Представлення концептуальній моделі засобами моделі даних субд
- •6.2 Типові моделі даних субд і представлення концептуальної моделі
- •6.2.1. Мережева модель даних
- •6.2.2. Ієрархічна модель даних
- •6.2.3. Реляційна модель даних
- •6.2.4. Багатовимірна модель даних
- •6.3. Засоби автоматизованого проектування концептуальної моделі
- •Лекція 6
- •Друга стадія концептуального проектування бд. (Моделі даних субд. Представлення концептуальної моделі засобами моделі даних субд)
- •6.1. Представлення концептуальній моделі засобами моделі даних субд
- •6.2 Типові моделі даних субд і представлення концептуальної моделі
- •6.2.1. Мережева модель даних
- •6.2.2. Ієрархічна модель даних
- •6.2.3. Реляційна модель даних
- •6.2.4. Багатовимірна модель даних
- •6.3. Засоби автоматизованого проектування концептуальної моделі
- •Лекція 7
- •Формалізація реляційної моделі
- •7.1. Формалізований опис відношень і схеми відношень
- •7.2. Маніпулювання даними в реляційній моделі
- •7.3. Операції реляційної алгебри
- •Лекція 8
- •Використання формального апарату для оптимізації схем відношень
- •8.1. Проблема вибору раціональних схем відношень
- •8.2. Функціональні залежності (залежності між атрибутами відношення)
- •8.3. Декомпозиція схеми відношення
- •8.4 .Вибір раціонального набору схем відношень шляхом нормалізації
- •8.5. Приклад нормалізації до 3нф
- •8.6. Цілісна частина реляційної моделі. Реалізація умови цілісності даних в сучасних субд
- •Лекція 9
- •Фізичні моделі даних (внутрішній рівень)
- •9.1. Структура пам'яті еом
- •9.2. Представлення екземпляра логічного запису
- •9.3. Організація обміну між оперативною і зовнішньою пам'яттю
- •9.4. Структури зберігання даних у зовнішній пам'яті еом
- •9.4.1. Послідовне розміщення фізичних записів
- •Пошук запису із заданим значенням ключа
- •9.4.2. Розміщення фізичних записів у вигляді спискової структури
- •Пошук запису із заданим значенням ключа
- •9.4.3. Використання індексів (індексування)
- •Пошук і читання запису із заданим значенням ключа
- •Модифікація (коректування) запису
- •Видалення запису
- •Додавання запису
- •9.4.5. Розміщення записів з використанням хешування
- •Пошук запису із заданим значенням ключа і читання
- •Модифікації запису
- •Видалення запису
- •Додавання запису
- •9.4.6. Комбіновані структури зберігання
- •Лекція 10
- •Структура сучасної субд на прикладі Microsoft sql Server 2008
- •10.1 Загальна структура субд
- •10.2. Архітектура бази даних. Логічний рівень
- •Тип даних hierarchyid
- •Просторові типи даних
- •Індекси
- •Представлення
- •Складки
- •Обмеження
- •Правила
- •Значення за замовчуванням
- •10.3. Архітектура бази даних. Фізичний рівень
- •Файли і файлові групи
- •Сторінки і екстенти
- •Сторінки файлів даних
- •Організація таблиць та індексів
- •Управління роботою з екстентами і вільним місцем
- •Відстежування вільного місця
- •Лекція 11
- •Програмне забезпечення роботи з сучасними базами даних
- •11.1. Основні завдання програмного забезпечення баз даних
- •11.2. Проблеми створення і ведення реляційних баз даних
- •11.3. Поняття мови sql і його основні частини
- •11.3.1. Історія виникнення і стандарти мови sql
- •11.3.2. Переваги мови sql
- •11.3.2. Загальна характеристика sql
- •Термінологія
- •Різновиди sql
- •Лекція 12
- •Основні оператори мови sql. Інтерактивний sql
- •12.1. Загальне уявлення про основні оператори мови sql
- •12.2 Інтерактивний режим роботи з sql (інтерактивна sql)
- •12.3. Використання мови sql для вибору інформації з таблиці
- •12.4. Використання sql для вибору інформації з декількох таблиць
- •12.5. Використання sql для вставки, редагування і видалення даних у таблицях
- •Лекція 13
- •Використання мови sql у прикладних програмах
- •13.1. Програмний (вбудований) sql
- •13.2. Статичний sql
- •13.3. Динамічний sql
- •13.4. Інтерфейси програмування додатків (api). Db‑Library, odbc, oci, jdbc
- •Протокол odbc
- •Протокол jdbc
- •Бібліотека db-Library
- •Лекція 14
- •Напрями розвитку баз даних
- •14.1. Об'єктно-орієнтований підхід до організації баз даних
- •Об'єктно-орієнтоване програмування
- •Об'єктно-орієнтовані бази даних
- •Об'єктно-реляційні субд
- •14.2. Розподілені бази даних
- •14.3. Сховища даних
- •Основи криптології
Протокол odbc
ODBC (Open Database Connectivity – відкритий доступ до баз даних) – розроблений компанією Microsoft універсальний інтерфейс програмування додатків для доступу до баз даних [5].
Основною метою розробки протоколу ODBC вважається стандартизація механізмів взаємодії з різними СУБД. Основна проблема, пов'язана з розробкою додатків, що взаємодіють з базами даних на основі спеціальних SQL API, полягала в тому, що кожна СУБД мала власний програмний інтерфейс доступу, кожен з них мав свої особливості і функціонував не зовсім так, як інші. У зв'язку з цим розробка додатку істотно залежала від використовуваної СУБД. Компанія Microsoft зробила важливий крок для вирішення цієї проблеми. Основна ідея полягала в розробці універсального інтерфейсу на рівні сімейства операційних систем Windows, який міг би бути підтриманий в різних СУБД.
Розглянемо коротко структуру програмного забезпечення ODBC [5]:
інтерфейс викликів функцій ODBC: це так званий верхній рівень ODBC, що містить API, який і використовується безпосередньо додатками. Даний API реалізований у вигляді бібліотеки динамічної компоновки Dll і входить до складу операційної системи Windows;
драйвери ODBC: це так званий нижній рівень ODBC, що містить набір драйверів для СУБД, які підтримують протокол ODBC. В межах технології для кожної СУБД може бути розроблений відповідний ODBC-драйвер, який буде проміжною ланкою між прикладною програмою і СУБД, транслюючи виклики функцій СУБД у виклики внутрішніх спеціалізованих функцій СУБД. Таким чином вирішується проблема стандартизації. Для багатьох сучасних СУБД існують спеціалізовані драйвери ODBC, окремо встановлювані в операційну систему;
диспетчер драйверів ODBC: даний програмний механізм представляє середній рівень ODBC, управляючи процесом завантаження необхідних драйверів.
Схема виконання програми з використанням протоколу ODBC для доступу до даних наводиться на мал. 13.5.
Мал. 13.5. Схема виконання програми з використанням протоколу ODBC для доступу до даних
Перелік деяких базисних функцій ODBC API наводиться в наступній таблиці.
Таблиця 13.3. Базисні функції ODBC API |
||
Призначення |
Функція |
Опис |
З'єднання з джерелом даних
|
SQLAlocEnv
|
Отримує покажчик оточення. Одне оточення може служити для створення декількох з'єднань. |
SQLAlIoc Connect |
Отримує покажчик з'єднання.
|
|
SQLConnect
|
З'єднується з вказаним драйвером, використовуючи ім'я джерела даних, ідентифікатор користувача і пароль. |
|
Підготовка SQL запитів
|
SQLAllocStmt |
Розміщує покажчик вираження. |
SQLPrepare
|
Готує SQL вираження для подальшого використання. |
|
SQLGet CursorName |
Повертає ім'я, пов'язане з покажчиком вираження. |
|
SQLSet CursorName |
Встановлює ім'я курсору.
|
|
Виконання запитів
|
SQLExecute
|
Виконує заздалегідь підготовлений запит. |
SQLExec Direct |
Виконує запит.
|
|
Вибірка результатів і інформації про результати
|
SQLRow Count
|
Повертає кількість записів, задіяних в операціях вставки, видалення, модифікації. |
SQLNum ResultCol |
Повертає кількість колонок у вибраному наборі даних. |
|
SQLDescribe Col |
Описує колонку у вибраному наборі даних. |
|
SQLCol Attributes |
Описує атрибути колонки у вибраному наборі даних. |
|
SQLBindCol
|
Привласнює місце в пам'яті для колонки у вибраному наборі даних і вказує її тип даних. |
|
SQLFetch
|
Повертає декілька наборів даних. |