16. База данных. Архитектура баз данных. Уровни архитектуры ANSI/SPARC. Компоненты системы баз данных. Категории пользователей БД. Функции администратора БД. Функции СУБД.
Основу функционирования информационных систем составляют базы данных. В широком понимании база данных представляет совокупность сведений о реальных процессах, событиях или явлениях, относящихся к определенной предметной области и организованной таким образом, чтобы обеспечить удобное представление этой совокупности, как в целом, так и в любой ее части.
Архитектура ANSI/SPARC (трехуровневая архитектура)включает следующие уровни: внутренний, концептуальный и внешний.
Внешний уровень определяет точку зрения пользователей на базу данных. Отдельного пользователя интересует не вся БД, а только некоторая часть ее. Пользовательские представления отображаются в данные концептуального уровня
Концептуальный уровень отражает обобщенную модель предметной области, для которой создавалась база данных. На этом уровне база данных представлена в наиболее общем виде. Концептуальное представление – это представление данных такими, какие "они есть на самом деле", а не то, какими их представляют пользователи, абстрактное представление всей базы данных. Концептуальное представление определяется с помощью концептуальной схемы.
Внутренний уровень связан со способами хранения и извлечения данных. Внутреннее представление отражает низкоуровневую структуру базы данных. Понятие структуры физической базы данных включает: формат хранимой записи, структура путей доступа и размещение записей на физических устройствах и т.д. Внутреннее представление описывается средствами внутренней схемы, определяющей не только типы хранимых записей, но и индексы, представления памяти, упорядочение полей и т.д.
Трехуровневая архитектура позволяет обеспечить физическую независимость хранимых данных. Разработчик базы данных может при необходимости изменить физическую модель данных, переписав хранимые данные на другие носители информации и реорганизовав их физическую структуру. Может подключить к системе любое число новых пользователей (новых приложений), дополнив, если надо, концептуальную модель. Указанные изменения не будут замечены существующими пользователями системы (окажутся "прозрачными" для них), так же как не будут замечены и новые пользователи. Следовательно, независимость данных обеспечивает возможность развития системы баз данных без разрушения существующих приложений.
Система баз данных представляет собой совокупность следующих взаимосвязанных компонентов: данные (хранимая база данных), программное обеспечение (СУБД, приложения, операционная система и т.д.), аппаратное обеспечение (процессор, оперативная память, магнитные диски для хранения информации и т. д.), пользователи
Данные являются интегрированными и общими. Под понятием интегрированные данные подразумевается возможность представить БД как объединение нескольких файлов данных полностью или частично не перекрывающихся. Под понятием общие данные подразумевается возможность использования отдельных областей данных несколькими различными пользователями, т.е. каждый из этих пользователей может иметь доступ к одной и той же области данных в одно и то же время.
С базами данных работают различные категории пользователей: прикладные программисты, конечные пользователи, администраторы базы данных.
Конечные пользователи – это основная категория пользователей. Конечные пользователи работают с базами данных через рабочую станцию или терминал, используя при этом либо приложения, либо интерфейс СУБД. В зависимости от особенностей создаваемой базы данных круг конечных пользователей может существенно различаться. Конечным пользователем может быть, например, клиент компьютерной фирмы, просматривающий каталог продукции или услуг, или начальник отдела, анализирующий перспективы ее развития.
Прикладные программисты разрабатывают внешние приложения, которые позволяют выполнять над данными все стандартные операции: выборку, удаление и изменение существующей информации, вставку новой информации.
Администратор базы данных (АБД) – под этим понятием подразумевается лицо (или группа лиц, возможно, целое штатное подразделение), на которое возложено управление средствами базы данных организации. В его функции входит: •координировать все действия по проектированию, реализации и ведению базы данных; учитывать перспективные и текущие требования пользователей; следить, чтобы база данных удовлетворяла актуальным информационным потребностям; •анализировать существующие программные средства и возможность их использования в базе данных, разрабатывать программно-технические мероприятия по развитию базы данных; •разрабатывать и реализовывать меры по обеспечению защиты данных от некомпетентного их использования, от сбоев технических средств, по обеспечению секретности определенной части данных и разграничению доступа к данным; •выполнять работы по ведению словаря данных; контролировать избыточность и противоречивость данных, их достоверность; •следить за тем, чтобы БД отвечала заданным требованиям по производительности, т. е. чтобы обработка запросов выполнялась за приемлемое время; выполнять при необходимости изменения методов хранения данных, путей доступа к ним, связей между данными, форматов данных; определять степень влияния изменений в данных на всю БД; координировать вопросы технического обеспечения системы аппаратными средствами исходя из требований, предъявляемых БД к оборудованию; •координировать работы системных программистов, разрабатывающих дополнительное программное обеспечение для улучшения эксплуатационных характеристик системы; •координировать работы прикладных программистов, разрабатывающих новые приложения и выполнять проверку и включение прикладных программ в состав программного обеспечения системы; •работать с конечными пользователями, в том числе и по вопросам обучения и консультирования и т.п.
Рассмотрим функции СУБД подробнее: •СУБД должна предоставлять пользователям и программам два типа языков: язык описания данных (для описания логической структуры данных) и язык манипулирования данными (для выполнения запросов пользователя на выборку, изменение, удаление данных). •СУБД должна контролировать пользовательские запросы и следить за выполнением правил безопасности и целостности, определенные АБД. •В СУБД должен быть предусмотрен механизм восстановления данных. •СУБД должна обеспечить функцию словаря данных. Словарь данных содержит "данные о данных", так называемые метаданные. Метаданные словаря предоставляются в виде, удобном для восприятия человеком и характеризуют состав и структуру пользовательских данных в базе данных. Словарь данных предназначен для документирования разработки системы базы данных, справочного обслуживания ее пользователей, а также для персонала АБД.
СУБД является важнейшим, но не единственным компонентом программного обеспечения. Другие программные компоненты: средства разработки приложений, средства проектирования, утилиты, генераторы отчетов и т. д.