MIDAS. Практическое применение

Информация - Компьютеры, программирование

Другие материалы по предмету Компьютеры, программирование

MIDAS. Практическое применение

Роман Игнатьев

Введение

Необходимые знания: Перед прочтением рекомендуется ознакомиться с технологией MIDAS хотя бы на уровне демонстрационных приложений, поставляющихся с Delphi.

Технология MIDAS (Multi-tier Distributed Application Services Suite, Сервис для создания многоуровневых распределенных приложений) была предложена фирмой Borland уже довольно давно, первое приложение с ее использованием я написал еще в 98 году, на Delphi 4. И с тех пор практически все приложения для работы с базами данных создаются мной именно на основе MIDAS. О преимуществах, думаю, говорить не надо даже простое разделение приложения на две части, одна из которых работает с базой данных (сервер приложений), а другая обеспечивает интерфейс пользователя, создает значительные удобства как при разработке приложения, так и при его использовании.

Сейчас существует множество статей и книг по технологии создания многозвенных приложений на Delphi, но, к сожалению, мне не удалось найти литературы, в которой бы рассматривались некоторые интересующие меня вопросы. Дело в том, что во всех примерах создается трехзвенное приложение, в котором сервер приложений просто соединяет сервер БД с клиентской частью, просто абстрагируя работу с базой данных.

С одной стороны, это дает некоторое преимущество при переходе с двухуровневой технологии (клиент-сервер) на трехуровневую, для чего компоненты доступа к базе данных из клиентской части переносятся в сервер приложений. С другой стороны, хочется большего, а именно переноса на сервер не только работы с таблицами базы данных, но и основной логики приложения, оставляя клиентской части только задачу взаимодействия с пользователем.

Ниже рассматривается очень простое приложение для работы с сервером БД. База данных, с которой работает это приложение, содержит всего 3 таблицы. С его помощью мне хотелось бы показать некоторые способы создания полноценного сервера приложений, обеспечивающего полную обработку данных.

Все, что написано ниже, относится к Delphi 5, в качестве сервера выбран Interbase 5.6. Именно эти продукты я использовал в большинстве проектов. Однако база данных работает и на более старших версиях Interbase, я проверял ее работоспособность, в частности, на IB6, а исходные тексты приложения с минимальными изменениями можно компилировать на старших версиях Delphi. К сожалению, некоторые изменения делать все же придется, так как MIDAS постоянно развивается. Но, как правило, такие изменения носят косметический характер, и сделать их несложно. Как изменить проект для компиляции на Delphi 6, будет рассказано в заключительной части. Несмотря на то, что в сервере приложений используются компоненты прямого доступа Interbase Express (IBX), нетрудно перейти на другой сервер БД, просто заменив компоненты доступа и немного изменив текст методов.

Исходя из практических соображений ниже описано создание трехуровневого приложения, включая разработку структуры базы данных. Мне не хотелось пользоваться готовыми примерами, входящими в поставку Interbase и Delphi, чтобы не придерживаться шаблонов, навязываемых ими.

Постановка задачи

Я собираюсь на простом примере показать возможности технологии, поэтому приложение будет работать всего с одним логическим объектом некоторым абстрактным документом, состоящим из заголовка и содержимого. Такая структура была выбрана из-за того, что связь “мастер-таблица - подчиненная таблица” (master-detail) очень часто встречается на практике, и также часто в приложениях встречается обработка различных документов.

“Документ” здесь понимается как некоторая абстракция, напоминающая реальные документы, такие, как накладная или счет.

Разумеется, необходимо обеспечить одновременную работу с документами нескольких пользователей.

Описание документа

Заголовок документа прост, и состоит из следующих полей:

Номер номер документа.

Дата дата выписки, по умолчанию текущая.

Поставщик имя, телефон.

Получатель также имя и телефон.

Сумма общая сумма по документу.

Поставщик и получатель будут выбираться из единого справочника клиентов, содержащего только два поля: имя и телефон.

Документ содержит записи со сведениями о перемещении неких товаров. Содержимое документа это таблица в базе данных, записи которой состоят из следующих полей:

Порядковый номер

Номер документа, к которому относится.

Наименование - наименование товара.

Количество.

Цена.

Сумма.

Результат может выглядеть следующим образом:

номер п/пнаименованиеколичествоценасумма1Что-то130.0030.002Что-то еще210.5021.00...Пользователю должен выдаваться список документов с указанием реквизитов документа и его итоговой суммы.

Сумма документа будет рассчитываться сервером приложений на основе его содержимого.

Кроме этого, создадим итоговый отчет "шахматную" ведомость, где по одной оси расположены поставщики, а по другой получатели:

За период с (по дате документа)От когоКомуПолучатель1(имя)Получатель2(имя)...Поставщик1(имя)СуммаСуммаПоставщик2(имя)СуммаСумма...В отчет будут входить суммы из документов, даты которых попадают в заданный период.

Отчет, разумеется, получается также достаточно оторванным от жизни, мне просто хотелось показать с его помощью дополнительные возможности MIDAS.

Блокировки

Поскольку работать с БД будут сразу несколько пользователей, важно заблокировать документ на время редактирования документа пользователем. “Почетная обязанность” синхр?/p>