Эта книга предназначена для всех, кто желает освоить СУБД MySQL. Для ее чтения вам не нужны никакие специальные знания – достаточно быть пользователем Windows. Вы узнаете, как установить и запустить MySQL, как создать собственную базу данных, как работать с данными при помощи команд SQL, как администрировать базу данных и оптимизировать ее работу. Разработчики веб-приложений на языках PHP, Perl и Java найдут в этой книге полезные сведения по использованию базы данных MySQL в соответствующих приложениях. Для всех операций, которые вам предстоит выполнить, приводятся подробные пошаговые инструкции, все основные действия поясняются на примере учебной базы данных.
Полезная книга, все очень структурировано расписано, есть нюансы с которыми можно поспорить, но в целом годно. Например, когда речь шла о ключах, указывалось что формат должен быть serial, хотя это далеко не всегда подойдет. Не все таблицы будут содержать огромное кол-во строк и этот вариант будет работать медленней чем обычный int с параметрами.
Набор данных, выводимый командой EXPLAIN, содержит детальную информацию о ходе выполнения запроса. Каждая строка в этом наборе описывает одну из операций, составляющих запрос. Например, команда
EXPLAIN SELECT name,address,product_id,qty FROM Customers, Orders WHERE Customers.id=customer_id AND date='20007-12-12';
выводит результат, представленный в табл. 6.1. Таблица 6.1. Результат выполнения команды EXPLAIN
Столбец table (таблица) содержит имя обрабатываемой таблицы, а столбец select_type (тип запроса) указывает место операции в структуре запроса: • SIMPLE – простой запрос без вложенных запросов и UNION; • PRIMARY – первый запрос в UNION или внешний запрос, имеющий вложенные запросы; • UNION – второй и последующие запросы в объединении UNION; • DEPENDENT UNION – второй и последующие вложенные запросы в объединении UNION, связанные с внешним запросом (о связанных подзапросах вы узнали в подразделе «Операторы сравнения с результатами вложенного запроса»); • UNION RESULT – операция объединения результатов запросов; • SUBQUERY – вложенный запрос; • DEPENDENT SUBQUERY, UNCACHEABLE SUBQUERY – вложенный запрос, связанный с внешним запросом; • DERIVED – запрос, генерирующий промежуточный результат (такой запрос следует после ключевого слова FROM).
ROW_FORMAT <Формат> Данный параметр определяет формат таблицы. Таблица с типом InnoDB может иметь формат COMPACT или REDUNDANT. Формат COMPACT используется по умолчанию и является оптимальным. Для таблицы с типом MyISAM вы можете указать значение FIXED (статический формат) или DYNAMIC (динамический формат). Обратите внимание, что статический формат нельзя установить для таблицы, содержащей столбцы с типом TINYBLOB, TINYTEXT, BLOB, TEXT, MEDIUMBLOB, MEDIUMTEXT, LONGBLOB и LONGTEXT: если вы укажете для такой таблицы статический формат, он автоматически изменится на динамический. Примечание Проверить, какие форматы были фактически присвоены таблицам, вы можете с помощью команды SHOW TABLE STATUS; Эта команда выводит информацию обо всех таблицах в текущей базе данных. В столбце Row_format вы увидите текущий формат таблицы. Если вы приняли все необходимые меры для улучшения структуры таблиц, но запросы все равно выполняются медленно, попытаемся сделать более эффективными сами запросы