
- •Введение
- •Часть 2. Общая классификация архитектур информационных приложений
- •2.1. Файл-серверные приложения
- •2.2. Клиент-серверные приложения
- •2.2. Клиент-серверные приложения
- •2.3. Intranet-приложения
- •2.4. Склады данных (DataWarehousing) и системы оперативной аналитической обработки данных
- •2.5. Интегрированные распределенные приложения
- •Часть 3. Средства и методологии проектирования, разработки и сопровождения файл-серверных приложений
- •3.1. Традиционные средства и методологии разработки файл-серверных приложений
- •3.1.1. Системы программирования и библиотеки
- •3.1.2. Средства и методы разработки приложений на основе субд на персональных компьютерах
- •3.2. Новые средства разработки файл-серверных приложений
- •3.2.1. Общая характеристика современных средств
- •3.2.2. Примеры новых подходов
- •3.2.2.1. Пакет ms Access
- •3.2.2.2. Система Visual FoxPro
- •3.2.2.3. Среда программирования ca-Visual Objects
- •3.3. Перенос файл-серверных приложений в среду клиент-сервер
- •3.3.1. Библиотеки доступа к базам данных
- •3.3.2. Протокол odbc и его реализации
- •3.3.3. Укрупнение приложений (Upsigsing)
- •3.4. Рекомендации по использованию инструментальных средств разработки файл-серверных приложений
- •4.4. Классический подход к проектированию реляционных баз данных
- •4.4.1. Функциональные и прочие зависимости
- •4.4.2. Проектирование реляционных баз данных на основе принципов нормализации
- •4.4.2.1. Вторая нормальная форма
- •4.4.2.2. Третья нормальная форма
- •4.4.2.3. Нормальная форма Бойса-Кодда
- •4.4.2.4. Четвертая нормальная форма
- •4.4.2.5. Пятая нормальная форма
- •4.5. Концептуальные модели и схемы баз данных
- •4.5.1. Диаграммное представление
- •4.5.1.1. Основные понятия модели Entity-Relationship (Сущность-Связи)
- •4.5.1.2. Нормальные формы er-схем
- •4.5.1.3. Более сложные элементы er-модели
- •4.5.1.4. Получение реляционной схемы из er-схемы
- •4.5.2. Виды нотаций
- •4.5.2.1. Case-метод Баркера
- •4.5.2.2. Методология idef1
- •4.5.2.3. Подход, используемый в case-средстве Vantage Team Builder
- •4.6. Case-системы для проектирования информационных систем
- •4.6.1. Назначение и разновидности case-систем
- •4.6.2. Примеры и различия распространенных case-систем
- •4.6.2.4. Локальные средства (eRwin, bPwin, s-Designor, case.Аналитик)
- •4.6.2.5. Объектно-ориентированные case-средства (Rational Rose)
- •4.7. Физическое проектирование баз данных
- •4.7.1. Противоречия теории и практики
- •4.7.2. Денормализация для оптимизации
- •Часть 6. Информационные приложения, основанные на использовании "складов данных" (DataWarehousing)
- •6.1. Проблема интеграции данных
- •6.2. Подходы и имеющиеся решения
- •6.2.1. Компания ibm
3.3. Перенос файл-серверных приложений в среду клиент-сервер
Усложнение информационных приложений, их интеграция в корпоративные сети, создание распределенных БД коллективного пользования требуют новых инструментальных средств и "истинно реляционных" СУБД. Традиционно используемые "персональные" СУБД типа Clipper и FoxPro не могут обеспечить требуемый уровень надежности и достоверности информации, особенно при работе в сетях. Подобные СУБД не поддерживают целостность баз данных и не имеют механизмов управления транзакциями, что существенно затрудняет обеспечение логической непротиворечивости информации при сбоях оборудования и программ.
Возросшим требованиям удовлетворяет архитектура клиент-сервер, основанная на выделении одного узла сети под сервер БД с реляционной СУБД, поддерживающей максимальный уровень надежности хранения, ее актуальность и достоверность. До недавнего времени создание приложений для таких СУБД было делом непростым и требовало высокой квалификации, методика программирования на непроцедурном языке SQL не согласуется с опытом разработки приложений для СУБД на персональных компьютерах.
С другой стороны, накоплен большой опыт работы на системах семейства xBase, в частности, Clipper. Создано большое число прикладных программ, которые внедрены в эксплуатацию. При интеграции отдельных автоматизированных рабочих мест в корпоративные сети было бы желательно сохранить не только постановку задачи и применяемые алгоритмы, но и собственно программное обеспечение.
Существует несколько подходов к интеграции и адаптации файл-серверных приложений к архитектуре клиент-сервер:
использование библиотек доступа к серверам БД;
связь с сервером БД через открытый протокол ODBC;
укрупнение файл-серверных приложений.
Чтобы оценить возможности этих способов, рассмотрим их несколько подробнее.
3.3.1. Библиотеки доступа к базам данных
Библиотеки доступа к серверам приложений удобно применять для адаптации файл-серверных приложений, построенных на системах программирования типа Clipper или Clarion.
Система управления записями Clarion достаточно легко связывается с сервером баз данных Btrieve через библиотеку доступа. Нужно только заметить, что Btrieve не является SQL-сервером БД, что затрудняет программирование с использованием этого средства.
Приложения, построенные на Clipper, можно адаптировать с помощью программного интерфейса с выбранным сервером БД. Для примера рассмотрим библиотеку интерфейса Clipper-Oracle.
Интерфейс реализован в виде библиотеки функций, доступных для их использования в прикладных программах, написанных на языке Clipper, и выполняющих все необходимые операции над базой данных Oracle. Функции написаны на языках Clipper и Си.
С помощью функций этой библиотеки можно выполнять следующие операции над таблицами базы данных системы Oracle:
подключиться к системе Oracle;
вставить в базу данных новую строку;
удалить существующую строку;
произвести модификацию содержимого полей существующей строки;
выполнить поиск строк по заданному точному значению полей;
выполнить поиск строк по заданному шаблону значений полей;
выполнить поиск строк по их относительному номеру в заданной группе;
блокировать и разблокировать таблицы;
обрабатывать транзакции, в том числе с возможностью установки контрольных точек внутри одной транзакции.
В то же время для всех этих операций (кроме обработки транзакций) имеются соответствующие аналоги в системе Clipper, и все операции с базой данных системы Clipper могут быть реализованы с помощью функций предлагаемой библиотеки.
Кроме того, существует возможность прямого использования языка SQL, который является основным языком обработки данных не только в системе Oracle, но и в большинстве других развитых СУБД.
Версия языка SQL, реализованная в Oracle, ориентирована на стандарт этого языка и содержит ряд ограничений. Например, оператор Fetch позволяет перемещаться по результирующей таблице только в одном направлении, исключая возвраты назад. Функции библиотеки снимают эти ограничения.
С помощью функций библиотеки можно обрабатывать таблицы Oracle всех типов, в том числе виртуальные таблицы, кластеризованные таблицы, таблицы с индексами и без индексов. При этом обеспечивается преобразование форматов данных Oracle в форматы данных Clipper и наоборот.
Единицей обмена между прикладной программой и базой данных является строка таблицы, которая с точки зрения Clipper является массивом. Каждый элемент массива соответствует одному полю таблицы. Аналогично представляются ключи и поля поиска.
В состав библиотеки входят следующие функции:
INIT () подключение к Oracle;
OPEN () открытие таблицы;
INSERT () добавление строки;
UPDATE () корректировка строки;
DELETE () удаление строки;
SELECT () поиск строки;
NEXT () чтение следующей строки;
SET () чтение строки по относительному номеру;
SKIP () пропуск строк;
FILTER () выбор строк по условию;
GETIND () сохранение индекса;
SETIND () установка индекса;
COMMIT () конец транзакции;
SAVE () установка контрольной точки;
ROLL () откат транзакции;
LOCK () блокировка таблицы;
SQL () выполнение оператора SQL;
CLOSE () закрытие таблицы;
STOP () отключение от Oracle.
Предлагаемые функции не препятствуют использованию собственных средств управления данными Clipper, что позволяет совместно обрабатывать разнородные базы данных. Так, в качестве центральной может использоваться база данных Oracle на большой, мини- или персональной ЭВМ, а в качестве локальной может использоваться база данных Clipper на персональном компьютере пользователя.
В состав интерфейсных средств включен специальный модуль для автономной отладки прикладных программ без системы Oracle. Этот модуль выполняет все функции интерфейса на DBF-файлах, что позволяет разрабатывать и полностью отлаживать программы, используя только систему Clipper на обычном персональном компьютере. Кроме того, эта возможность позволяет разрабатывать прикладные программы сразу в двух вариантах - сетевом и автономном.
Такой подход позволяет сохранить ранее разработанное и внедренное программное обеспечение, обеспечить преемственность при разработке новых прикладных систем, поддержать единую технологию программирования.