Большая часть этой книги представляет собой описание возможностей СУБД MySQL и иллюстрирует применение MySQL на примерах приложений, манипулирующих данными, хранящимися в базах данных. Но перед тем как перейти к рассмотрению таких инструментов, необходимо, чтобы у читателя сложилось четкое представление о том, как работает MySQL. Это необходимо прежде всего для того, чтобы вы могли принимать осознанные решения, каким именно образом лучше всего создавать и оптимизировать приложения для выполнения конкретных задач.
С этой целью в данной главе внимание фокусируется прежде всего на общем представлении о компонентах и функциональных возможностях СУБД MySQL.
Обзор архитектуры СУБД MySQL
Архитектура MySQL основана на многоуровневой архитектуре, состоящей из первичных подсистем и компонентов поддержки, взаимодействующих между собой при чтении, анализе и выполнении запросов.
Первичные подсистемы
Архитектура MySQL состоит из пяти первичных подсистем, работающих вместе при обработке запроса, отправленного на сервер MySQL:
■ процессор обработки запросов;
■ диспетчер сохранения;
■ диспетчер буферизации;
■ диспетчер транзакций;
■ диспетчер восстановления.
Организация этих возможностей представлена на рис. 2.1. Для лучшего понимания взаимодействия этих частей между собой, опишем каждую из них в отдельности.
Процессор обработки запросов
Эта подсистема содержит три взаимосвязанных компонента:
■ анализатор синтаксиса;
■ оптимизатор запросов;
■ компонент исполнения.
Анализатор синтаксиса переводит поступающие команды SQL в понятную для процессора MySQL форму. Идентифицируются используемые объекты, и анализируется правильность синтаксиса. Анализатор синтаксиса также проверяет объекты на соответствие уровня привилегий вызывающей программы для работы с данными объектами.
Затем оптимизатор запросов оптимизирует синтаксис запроса для выполнения его компонентом исполнения. Оптимизатор запросов проверяет, каким индексом можно воспользоваться во время обработки запроса, чтобы этот запрос был обработан как можно быстрее и эффективнее. Он выбирает один из нескольких способов выполнения запроса и создает план выполнения, который будет понятен для компонента исполнения.
Оптимизатор запросов в своей работе использует принцип индукции с использованием вероятности, но если вам известен способ получения идеальных результатов обработки запроса, это позволит предотвратить использование оптимизатором неоптимального плана выполнения. MySQL предоставляет возможность подсказки процессору, что позволяет при обработке запроса воспользоваться специальными индексами, не прибегая к услугам оптимизатора.
После этого компонент исполнения интерпретирует план выполнения и, опираясь на полученную информацию, выполняет запросы на выборку записей к другим компонентам.
ТОП-10 популярных
Для работы с вещественными числами в MySQL предусмотрено три типа данных - это типы FLOAT, DOUBLE, DECIMAL. Числовой тип FLOAT...
БОЛЬШЕ БОЛЬШИХ LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Больше больших LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
НОУТБУК с блестящим экраном
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Иди и пиши. TravelMate C100
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Магнито-оптический дисковод DynaMO
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Компьютер для гурманов.«Эксимер ДМ»
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Для длинных строк, т.е. строк длиннее 255 символов, в MySQL предусмотрены типы BLOB (Binary Large Object, большой двоичный объект) и...
В дополнение к календарным типам, предназначенным для хранения даты и времени отдельно, MySQL также поддерживает гибридные типы данных DATETIME и...
Вообще, к изменению настроек сервера прибегают очень редко. В MySQL программа заранее настроена так, чтобы соответствовать самым распространенным и основным...
Все о MySQL. Техническое описание MySQL
28-12-2009
<< Предыдущая статья | Следующая статья >> |
Все о MySQL. Открытый код | Все о MySQL. Диспетчер сохранения |