1. Обновите статистику распределения индексов в таблице с помощью команды
ANALYZE TABLE <���Имя таблицы>;
2. Повторно выполните команду EXPLAIN. Если и после обновления статистики индекс не начал использоваться, добавьте в текст запроса после имени таблицы параметр FORCE INDEX (<���Имя индекса>). Сравните время выполнения запроса с параметром FORCE INDEX и без него и выберите оптимальный вариант.
Помимо введения индексов, существуют и другие способы ускорения запросов. Вот наиболее простые из них.
• Исключите получение лишней информации из базы данных. Результат запроса должен содержать только те данные, которые действительно необходимы. Например, если вы отображаете на веб-странице не более 20 товаров, не нужно получать из таблицы Products (Товары)
все данные. Вместо этого используйте запросы вида
SELECT <���Список столбцов> FROM <���Список таблиц>
[WHERE <���Условие отбора>]
…
LIMIT <���Количество строк> OFFSET <���Сдвиг>;
Так, для получения первой «порции» из 20 товаров выполните запрос
SELECT * FROM Products LIMIT 20 OFFSET 0;
Следующих 20 товаров —
SELECT * FROM Products LIMIT 20 OFFSET 20;
Затем
SELECT * FROM Products LIMIT 20 OFFSET 40;
и т. д.
• Максимально упростите систему привилегий доступа. Чем сложнее система привилегий, тем больше времени занимает проверка прав доступа при выполнении запросов (а также других SQL-команд). Хорошим решением является разграничение доступа на уровне баз данных и отказ от присвоения привилегий доступа к отдельным таблицам и столбцам. В этом случае контроль действий пользователей не требует обращения к таблицам tables_priv и columns_ priv (см. подраздел «Просмотр привилегий»).
• Если запрос содержит выражение, проверьте, не является ли вычисление этого выражения причиной замедления запроса. Для этого выполните команду
SELECT BENCHMARK(<���Количество повторений>,<���Выражение>);
Функция BENCHMARK() всегда возвращает значение 0, однако в сообщении о результате выполнения команды указывается время ее выполнения, благодаря чему вы можете оценить время вычисления выражения. Например, если ваш запрос включает вычисление синуса для каждой строки таблицы, выполните команду
SELECT BENCHMARK(10000000,SIN(1));
При использовании процессора с тактовой частотой 1,6 ГГц выполнение этой команды займет приблизительно 1 с. Таким образом, программа MySQL способна производить около 10 млн вычислений синуса в секунду, а значит, функция SIN() не оказывает существенного влияния на скорость запроса. Итак, мы рассмотрели способы оптимизации таблиц и запросов. В следующем разделе вы узнаете о том, как увеличить быстродействие сервера путем настройки системных переменных.
6.3. Параметры работы сервера
В процессе работы сервер MySQL использует множество буферов (кэшей) различного назначения. Если ваш компьютер располагает достаточной оперативной памятью, вы можете увеличить размеры буферов и тем самым повысить скорость выполнения операций, использующих эти буферы (благодаря уменьшению количества обращений к диску, которые выполняются медленно). В данном разделе мы рассмотрим переменные, которые задают размеры буферов, а также другие переменные, влияющие на производительность сервера.
Узнать текущие значения серверных переменных вы можете с помощью уже знакомой вам команды
SHOW VARIABLES;
Для изменения значения переменной можно использовать команду
SET GLOBAL <���Имя переменной>=<���Значение>;
однако установленное таким образом значение будет действовать только до момента перезапуска сервера MySQL. Поэтому лучше указать нужные значения переменных непосредственно при запуске сервера MySQL. • Если вы запускаете сервер вручную из командной строки (об этом говорилось в подразделе «Запуск и остановка сервера MySQL из командной строки» главы 1), укажите в команде запуска сервера параметр – <���Имя переменной> = <���Значение>, например
mysqld-nt –table-cache=256
• Если сервер MySQL был сконфигурирован как сервис Windows и запускается или автоматически, или с помощью панели управления, или с помощью MySQL Administrator (см. подразделы «Запуск и остановка сервера MySQL с помощью MySQL Administrators «Запуск и остановка сервера MySQL с панели управления» главы 1), откройте конфигурационный файл my.ini, находящийся в папке, где установлена программа MySQL, и добавьте параметр <���Имя переменной> = <���Значение> в раздел [mysqld] (см. рис. 5.9). Сохраните файл my.ini. Новые значения переменных вступят в действие после перезапуска сервера.
Читать дальше
Конец ознакомительного отрывка
Купить книгу