- •Оглавление
- •История развития баз данных
- •Тенденции в мире систем управления базами данных
- •1. Реляционные системы
- •1.1 Стандартизация языка sql
- •1.2 Использование мультипроцессорных организаций
- •1.3 Интеграция и интероперабельность
- •2. Постреляционные системы
- •2.1 Базы сложных объектов, реляционная модель с отказом от первой нормальной формы
- •2.2 Активные базы данных
- •2.3 Дедуктивные базы данных
- •2.4 Темпоральные базы данных
- •2.5 Интегрированные или федеративные системы и мультибазы данных
- •2.6 Субд следующего поколения
- •2.7 Объектно-ориентированные базы данных
- •3. Распределенные субд
- •3.1 Синхронизация доступа к данным
- •3.2 Управление транзакциями
- •3.3 Поддержание копий данных в нескольких узлах сети
- •3.4 Фрагментация объектов бд
- •3.5 Алгоритмы выполнения реляционных операций
- •4. Системы бд с многоуровневой защитой
- •Состав и функции систем управления базами данных
- •Информационная модель данных, ее состав (концептуальная, логическая и физическая модели)
- •Три типа логических моделей баз данных: иерархическая, сетевая, реляционная
- •Типы взаимосвязей в модели: «один к одному», «один ко многим», «многие ко многим»
- •Обеспечение непротиворечивости и целостности данных в базе
- •Реляционная модель данных
- •1. Основные понятия реляционной модели данных
- •2. Основы реляционной алгебры
- •Нормализация баз данных
- •Этапы проектирования баз данных
- •Классификация моделей данных
- •Инфологическое моделирование предметной области.
- •Модель "сущность-связь"
- •Концептуальные и физические er-модели
- •Принципы поддержки целостности в реляционной модели данных. Целостность базы данных.
- •1. Ограничения первичного ключа
- •2. Ограничение уникальности
- •3. Ограничение внешнего ключа
- •4. Ограничение значения по умолчанию
- •Индексирование
- •Защита информации в базах данных
- •Сравнительный анализ субд
- •Критерии выбора субд при создании информационных систем
- •Администрирование базы данных
Тенденции в мире систем управления базами данных
Системы управления базами данных (СУБД) играют исключительную роль в организации современных промышленных, инструментальных и исследовательских информационных систем. Тематика СУБД поистине безгранична. В предлагаемом коротком обзоре описываются наиболее интересные направления исследований и разработок.
1. Реляционные системы
Хотя многие полагают, что реляционные СУБД, являясь наиболее распространенным современным аппаратом построения информационных систем, не представляют уже интереса в научном отношении, остается еще много нерешенных или решенных не полностью проблем. Об этом свидетельствует поток статей, посвященных тематике чисто реляционных систем, а также активная деятельность компаний-производителей коммерческих реляционных систем, стремящихся улучшать свои продукты и придавать им новые качества.
Продолжающаяся работа исследователей затрагивают вопросы оптимизации запросов, новых алгоритмов выполнения реляционных операций, оптимизации структур хранения данных и другие аспекты, непосредственно определяющие эффективность СУБД. Те же самые вопросы занимают и разработчиков коммерческих СУБД, которые, кроме того озабочены и более прикладными проблемами. Рассмотрим немного более подробно (но без технических деталей) существо некоторых из этих вопросов и то, каким образом они решаются в наиболее развитых коммерческих продуктах.
1.1 Стандартизация языка sql
Для всех современных коммерческих реляционных СУБД основным языком доступа к базам данных является SQL. В 1989 г. появился первый международный стандарт этого языка, и большинство производителей СУБД объявляют свои системы соответствующими этому стандарту. Но стандарт 1989 г. был довольно ограниченным (например, в него не входили средства манипулирования схемой БД, динамический SQL и т.д.), а многие вошедшие в стандарт аспекты языка были специфицированы недостаточно строго. Поэтому разные реализации различаются в достаточно важных вопросах.
В 1992 г. был принят новый стандарт SQL-92. Этот язык существенно более сложен, чем SQL-89, а конструкции SQL-92 специфицированы в стандарте существенно более полно. Первой компанией, которая объявила о соответствии своего продукта новому стандарту, была компания Oracle со своей седьмой версией (это произошло прямо в 1992 г.). Теперь и все остальные компании обещают вскоре выпустить продукты, соответствующие стандарту SQL-92.
Кроме того, как это бывает всегда, производители стремятся добавить к своим продуктам качества, превышающие требования стандарта. Например, современные версии Oracle и Ingres содержат возможности определения триггеров (подробнее об этом см. ниже), в системе uniVerse компании VMark поддерживается расширенная ненормализованная реляционная модель и т.д. Другими словами, компании стремятся смотреть в будущее, предвидя требования следующего стандарта SQL (его условно называют SQL-3; ожидается принятие этого стандарта в 1995 г.).
1.2 Использование мультипроцессорных организаций
Уже довольно давно развитые коммерческие СУБД основываются на архитектуре "клиент-сервер". При этой организации наиболее трудоемкие операции над базами данных выполняются на выделенном компьютере-сервере, который должен быть достаточно мощным и обладать соответствующим набором ресурсов основной и внешней памяти. До поры серверная часть СУБД обладала простой организацией: запросы, поступающие из клиентских частей системы, обрабатывались последовательно с небольшой оптимизацией для совмещения процессорной работы с работой устройств внешней памяти.
Однако с появлением на рынке мультипроцессорных симметричных аппаратных архитектур, производители СУБД были вынуждены пересмотреть организацию своих серверов, допустив в них внутреннюю параллельность. Естественно, это требует очень основательного перепроектирования системы с ее существенным усложнением. Заметим, что в большинстве случаев компании пошли на это после появления в ОС UNIX механизма "легковесных" процессов (threads).
О серьезности этой работы говорит тот факт, что, например, в компании Informix было образовано новое подразделение, занимающееся исключительно вопросами распараллеливания работы серверов.
