Диспетчер доступа к данным - Data Access Manager

В Диспетчер доступа к данным (DAM) был база данных доступ API для классическая Mac OS, представленный в 1991 году как расширение Система 7. По концепции похож на ODBC, DAM не использовался, и в конце 1990-х годов был прекращен. Лишь немногие продукты когда-либо использовали его, хотя он использовался для некоторых чрезвычайно впечатляющих демоверсия в начале 1990-х гг. Более современные версии классической Mac OS и macOS, использовать ODBC для этой роли вместо этого.

Концепции

DAM и ODBC во многом похожи. Основная цель обеих систем заключалась в отправке «строк запроса» поставщику данных, который мог бы ответить (потенциально) «набором результатов», состоящим из строк данных. Обе системы должны были преобразовывать данные в соответствующие форматы системы и обратно, например, целые числа и строки. Кроме того, оба предоставляли подсистему связи, которая скрывала детали отправки запросов и данных между клиентом и сервером.

Как и большинство программного обеспечения Apple, DAM попыталась максимально упростить процесс запроса для пользователей, как пользователей приложений, так и программистов, пишущих эти приложения. Одна особенно примечательная особенность - это концепция «документов запроса». Документы запросов содержали любое количество предопределенных запросов (или других серверных команд) вместе с дополнительным кодом для их изменения перед отправкой на сервер. Например, типичный документ запроса может содержать строку запроса, которая будет регистрироваться на сервере базы данных, и, если это было успешно, найдите текущую дату на локальном клиентском компьютере с помощью вызова Mac OS, а затем используйте эту дату в запросе. который возвращает запасы на складе на заданную дату. Документы запроса могут также включать компьютерный код и ресурсы, необходимые для поддержки этого процесса, например, диалоговое окно с запросом имени пользователя и пароля.

Приложения могут использовать документы запроса, не имея представления о внутреннем устройстве запроса. Они просто открыли документ, который состоял из серии Ресурсы, и запускал каждый ресурс запроса внутри по очереди. DAM обеспечит выполнение любого необходимого кода в документе, даже если приложение даже не узнает об этом, и в конечном итоге результаты будут переданы обратно в приложение для отображения. Вся операция была непрозрачной, что позволяло приложениям легко добавлять поддержку DAM.

DAM также включал еще два прямых API, интерфейс высокого уровня и интерфейс низкого уровня. Высокий уровень был довольно похож на использование документов запросов, хотя ожидалось, что приложение будет создавать запросы в коде, а не в ресурсах. Интерфейс высокого уровня во многом аналогичен общедоступному интерфейсу ODBC. Низкий уровень позволял программисту вмешиваться в любой момент процесса запроса, например, извлекать данные построчно.

Одно из основных различий между DAM и ODBC возникло в основном случайно. До разработки DAM Apple приобрела промежуточное ПО для баз данных, которое они продавали как Язык доступа к данным, или DAL. DAL был, по сути, стандартизированным SQL с трансляторами для различных баз данных, которые работали на стороне сервера. Стандарты для SQL в то время были чрезвычайно простыми и относительно плохо поддерживаемыми. DAL решал эту проблему, имея единый язык и выполняя преобразование в другие системы и обратно. Клиентское программное обеспечение, включая DAM, могло отправлять запросы на стандартном языке DAL, которые затем переводились и выполнялись независимо от внутренней базы данных.

Напротив, ODBC с самого начала разрабатывался как система на основе SQL, основанная на стандартизированных Интерфейс уровня вызовов из X / Открыть (теперь часть Открытая группа ). В рамках OBDC каждый источник данных выглядел как SQL-сервер. Для бессерверных источников, таких как текстовые файлы, локальный синтаксический анализатор SQL интерпретирует команды и читает файл. В ODBC все драйверы источников данных должны понимать SQL и при необходимости переводить его на локальный диалект, а также преобразовывать данные в стандартные форматы при их возврате.

Это различие сделало DAM гораздо менее полезным, чем ODBC на практике. Поскольку ожидалось, что DAL будет обеспечивать стандартизацию запросов, DAM не имел уровня, аналогичного ODBC, для перевода различных диалектов. Чтобы DAM был действительно полезным, пользователю также нужно было купить и установить сервер DAL для своей конкретной базы данных. Общеизвестно, что DAL медленный и дорогой, серьезно снижающий общую стоимость DAM. Кроме того, DAM не стандартизировал язык для доступа к источникам данных, отличным от SQL; адаптер для текстового файла может использовать вместо этого язык, отличный от SQL, или систему, полностью основанную на вызовах функций. Также не было никаких простых интерфейсов для текстовых файлов или аналогичных источников данных, включенных в базовую установку DAM.

Использует

Одним из основных клиентов DAM был HyperCard, Менеджер данных Apple /быстрая разработка приложений система. Сочетание превосходной системы форм HyperCard с данными из DAM привело к тому, что никто никогда не видел до приложений с графическим интерфейсом, основанных на данных. Наиболее распространенная демонстрация системы показала, что стек HyperCard запрашивает серию Баскин-Роббинс баз данных, что раньше было невозможно, потому что каждая региональная область использовала свои собственные серверы баз данных, которые теперь DAL объединил в один. Повторный заказ для увеличения запасов можно было бы сделать, перетащив серию шариков мороженого на графическое отображение текущего складского инвентаря.

Система была настолько впечатляющей, что заставила других поставщиков баз данных изо всех сил пытаться предоставить аналогичные системы; Корпорация Oracle сразу купил PLUS из Программное обеспечение Spinnaker, выпуская сначала как Карта Oracle, а потом Объекты Oracle Media. Другие компании пошли по тому же пути, и вскоре интерфейс базы данных, управляемый событиями, стал стандартной функцией большинства систем.

Ряд других приложений также использовали эту систему, возможно, по иронии судьбы различные продукты Microsoft Office делают это с большой регулярностью. В остальном поддержка DAM была довольно редкой, и продукт не получил широкого распространения. Возможно, во многом это произошло из-за неполного характера системы DAM. в целом; необходимость в промежуточном программном обеспечении DAL в большинстве случаев и отсутствие недорогих построителей документов запросов (были и некоторые дорогие) сделали накладные расходы на использование DAM довольно высокими.

Работа над DAM закончилась в середине 1990-х годов и полностью исчезла незадолго до выпуска Mac OS X. Некоторое время была доступна "классическая" версия ODBC для Mac OS, хотя поддержка была ограничена. Начиная с выпуска OS X 10.2 Ягуар, Apple начала распространение версии iODBC кроссплатформенные драйверы ODBC. Начиная с OS X 10.4 Тигр Apple представила новую систему гораздо более высокого уровня, известную как Основные данные. Core Data позволяет разработчикам сериализовать данные в SQLite для обработки, аналогично ODBC при использовании с источником данных, отличным от SQL.

внешняя ссылка