Студопедия
Случайная страница | ТОМ-1 | ТОМ-2 | ТОМ-3
АрхитектураБиологияГеографияДругоеИностранные языки
ИнформатикаИсторияКультураЛитератураМатематика
МедицинаМеханикаОбразованиеОхрана трудаПедагогика
ПолитикаПравоПрограммированиеПсихологияРелигия
СоциологияСпортСтроительствоФизикаФилософия
ФинансыХимияЭкологияЭкономикаЭлектроника

Физическая и логическая структура баз данных.

Типы СУБД. | Модель сервера приложений. | Ссылочная целостность | Пользовательская целостность | Создание объекта DAO.Recordset, его типы. | Свойства объекта DAO.Recordset. | Операции над отношениями в БД. | Объекты ADO. | Создание запросов на выборку на SQL языке (Select) | Count(выражение) |


Читайте также:
  1. A. Физическая жизнь людей
  2. III. Організаційна структура і виборні органи Профспілки
  3. III. СТРУКТУРА ТА ТЕХНІЧНЕ ОФОРМЛЕННЯ КУРСОВОЇ РОБОТИ
  4. Pис. 12. Структура алмаза
  5. v. государственный транспорт (инфраструктура);
  6. VI. Психологическая классификация участников антипрививочного движения.
  7. Акты применения права: понятие, признаки, виды, структура. Отличие акта применения права от нормативно-правового акта

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

Одна из основных функций СУБД – управление данными во внешней памяти. Файловая система не всегда управляет файлами оптимально с точки зрения СУБД поэтому эти функции берёт на себя СУБД.

СУБД хранит во внешней памяти следующие объекты: строки отношений, управляющие структуры (индексы) созданные с целью повышения эффективности выполняемых запросов, журнальную информацию (надёжное хранение данных), служебную информацию.

Доступ к базе данных.Основная единица хранения информации на уровне файла – страница.

 

СУБД ↔диспетчер файлов ↔ диспетчер дисков ↔ БД

 

Страница – блок фиксируемой длинны обрабатываемой при дисковых операциях как единое целое. В SQL Server размер страницы 8 Кб. Для более эффективного управления используют extent по 8 страниц в каждом.

В SQL Server могут быть:

1) Data хранятся данные кроме типов text, image.

2) Index

3) Text/Image

4) Page Free Space → 1 байт

5) Global application map (GAM) использование extant

6) Index allocation map (IAM)

Extant бывают однородные и смешанные

Структура файла данных:

Заголовок файла PFS GAM DATA DATA

При необходимости вставить несколько строк в таблицу SQL просматривает страницу Index Allocation Map для поиска extent принадлежащей этой таблице. Когда extent наеден просматривается PFS. Если ни одна из страниц не имеет достаточного места для вставки выделяется новый свободный extent/

Физические структуры используемые для хранения данных в БД

1) Последовательные файлы

2) Файлы с прямым доступом

3) Индексные файлы

4) Инвертированные списки

5) Бинарные деревья

 

7. Архитектура централизированных сетевых баз данных: файл-сервер, клиент-сервер, сервер приложений.

Любое приложение работающее с базой данных можно разделить на:

1) Presentation logic – несёт функции ввода и отображения.

2) Business logic часть кода реализующая алгоритм решения задач.

3) Database logic – реализуется средствами SQL.

4) Компонент управления данными DBMS (СУБД).

5) Компонент выполняющий служебные функции.

1. В архитектуре "файл-сервер" вся тяжесть выполнения запросов к базе данных и управления целостностью базы данных ложится на приложение пользователя. База данных на сервере является пассивным источником данных.

Кардинальных различий с точки зрения архитектуры между однопользовательской архитектурой и архитектурой "файл-сервер" нет. И в том, и в ином случае в качестве СУБД применяются так называемые "персональные" (или "настольные", "локальные") СУБД, такие как paradox, dbase и пр. Сама база данных в этом случае представляет собой набор таблиц, индексных файлов, файлов полей комментариев (memo-полей) и пр., хранящихся в одном каталоге на диске в виде отдельных файлов.

В ходе эксплуатации были выявлены общие недостатки файл-серверного подхода при обеспечении многопользовательского доступа к базе данных.

Вся тяжесть вычислительной нагрузки при доступе к базе данных ложится на приложение клиента, что является следствием принципа обработки информации в системах "файл-сервер": при выдаче запроса на выборку информации из таблицы вся таблица базы данных копируется на клиентское место, и выборка осуществляется на клиентском месте. Локальные СУБД используют так называемый "навигационный подход", ориентированный на работу с отдельными записями.

Не оптимально расходуются ресурсы клиентского компьютера и сети; например, если в результате запроса мы должны получить 2 записи из таблицы объемом 10000 записей, все 10000 записей будут скопированы с файл-сервера на клиентский компьютер; в результате возрастает сетевой трафик и увеличиваются требования к аппаратным мощностям пользовательского компьютера.В базе данных на файл-сервере гораздо проще вносить изменения в отдельные таблицы, минуя приложения, непосредственно из инструментальных средств (например, из утилиты database desktop фирмы borland для файлов paradox или dbase); подобная возможность облегчается тем обстоятельством, что, фактически, у локальных СУБД база данных – понятие более логическое, чем физическое, поскольку под базой данных понимается набор отдельных таблиц, сосуществующих в едином каталоге на диске. Все это позволяет говорить о низком уровне безопасности – как с точки зрения хищения и нанесения вреда, так и с точки зрения внесения ошибочных изменений.

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

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

Поскольку настольные СУБД не содержат специальных приложений и сервисов, управляющих данными, а используются для этой цели файловые сервисы операционной системы, вся реальная обработка данных в таких СУБД осуществляется в клиентском приложении, и любые библиотеки доступа к данным в этом случае также находятся в адресном пространстве клиентского приложения. Поэтому при выполнении запросов данные, на основании которых выполняется такой запрос (это может быть одна или несколько таблиц целиком либо, если повезет, один или несколько индексов и выбранные с их помощью части таблиц), должны быть доставлены в то же самое адресное пространство клиентского приложения. Это и приводит к перегрузке сети при увеличении числа пользователей и объема данных, а также грозит иными неприятными последствиями, например разрушением индексов и таблиц. Недаром до сих пор популярны утилиты для "ремонта" испорченных файлов настольных СУБД.

Недостатки архитектуры "файл-сервер" решаются при переводе приложений в архитектуру "клиент-сервер", которая знаменует собой следующий этап в развитии СУБД. Характерной особенностью архитектуры "клиент-сервер" является перенос вычислительной нагрузки на сервер базы данных (sql-сервер) и максимальная разгрузка приложения клиента от вычислительной работы, а также существенное укрепление безопасности данных – как от злонамеренных, так и просто ошибочных изменений.

БД в этом случае помещается на сетевом сервере, как и в архитектуре "файл-сервер", однако прямого доступа к базе данных (БД) из приложений не происходит. Функция прямого обращения к БД осуществляет специальная управляющая программа – сервер БД (sql-сервер), поставляемый разработчиком СУБД.

 

2. Архитектура "клиент-сервер" разделяет функции приложения пользователя (называемого клиентом) и сервера.

Приложение-клиент формирует запрос к серверу, на котором расположена БД, на структурном языке запросов sql, являющимся промышленным стандартом в мире реляционных БД. Удаленный сервер принимает запрос и переадресует его sql-серверу БД. sql-сервер – это специальная программа, управляющая удаленной базой данных. sql-сервер обеспечивают интерпретацию запроса, его выполнение в базе данных, формирование результата выполнения запроса и выдачу его приложению-клиенту. При этом ресурсы клиентского компьютера не участвуют в физическом выполнении запроса; клиентский компьютер лишь отсылает запрос к серверной БД и получает результат, после чего интерпретирует его необходимым образом и представляет пользователю.

Так как клиентскому приложению посылается результат выполнения запроса, по сети "путешествуют" только те данные, которые необходимы клиенту. В итоге снижается нагрузка на сеть. Поскольку выполнение запроса происходит там же, где хранятся данные (на сервере), нет необходимости в пересылке больших пакетов данных. Кроме того, sql-сервер, если это возможно, оптимизирует полученный запрос таким образом, чтобы он был выполнен в минимальное время с наименьшими накладными расходами. Всё это повышает быстродействие системы и снижает время ожидания результата запроса.

При выполнении запросов сервером существенно повышается степень безопасности данных, поскольку правила целостности данных определяются в базе данных на сервере и являются едиными для всех приложений, использующих эту БД. Таким образом, исключается возможность определения противоречивых правил поддержания целостности. Мощный аппарат транзакций, поддерживаемый sql-серверами, позволяет исключить одновременное изменение одних и тех же данных различными пользователями и предоставляет возможность откатов к первоначальным значениям при внесении в БД изменений, закончившихся аварийно.

Функциями приложения-клиента являются:

-Посылка к серверу запросов;

-Интерпретация результатов запросов, полученных от сервера, и представление их пользователю в требуемой форме;

-Реализация интерфейса пользователя.

sql-сервер должен быть загружен на момент принятия запроса клиента. Функциями сервера БД являются:

-Прием запросов от приложений-клиентов, интерпретация запросов, выполнение запросов в БД, отправка результата выполнения запроса приложению-клиенту;

-Управление целостностью БД, обеспечение системы безопасности, блокировка неверных действий приложений-клиентов;

-Хранение бизнес-правил, часто используемых запросов в уже интерпретированном виде;

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

В архитектуре "клиент-сервер" используются так называемые "удаленные" (или "промышленные") СУБД. Промышленными они называются из-за того, что именно СУБД этого класса могут обеспечить работу информационных систем масштаба среднего и крупного предприятия, организации, банка. Локальные СУБД предназначены для однопользовательской работы или для обеспечения работы информационных систем, рассчитанных на небольшие группы пользователей.

К разряду промышленных СУБД принадлежат oracle, informix, sybase, ms sql server, db2, interbase и ряд других.

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

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

 


Дата добавления: 2015-08-26; просмотров: 192 | Нарушение авторских прав


<== предыдущая страница | следующая страница ==>
Эволюция развития баз данных.| Сервер баз данных

mybiblioteka.su - 2015-2024 год. (0.01 сек.)