Рубріки: HighloadТеория

Как правильно поставить индексы в MySQL?

Игорь Грегорченко

Чтобы правильно выбрать индексы в MySQL, необходимо провести анализ:

Нужно ли вообще ставить индексы?

Если slow log и анализ не показывают, что существуют проблемы с производительностью, тогда и индексы ставить незачем.

Ставить индексы нужно только на медленные запросы

Если будете ставить просто так – рискуете снизить производительность MySQL.

Самый простой метод – это выбрать один из медленных запросов и поставить индекс на колонку, которая используется в WHERE:

SELECT * FROM users WHERE email = 'user@mail.com'

В этом случае, необходимо просто добавить индекс на колонку email:

CREATE INDEX email ON users (email)

Если в запросе более одной колонки

Тогда необходимо ставить индексы на колонки в порядке их появления в WHERE:

SELECT * FROM users WHERE email = 'user@mail.com' AND name = 'Den'

В этом случае, необходимо просто добавить индекс на колонки email и name:

CREATE INDEX email_name ON users (email, name)

Более сложные случаи

Выше представлены очень примитивные подходы к установке индексов, которые не учитывают большого количества ньюансов. Читайте, как анализировать и ставить индексы в MySQL учитывая особенности запросов и движка.

Останні статті

Обучение Power BI – какие онлайн курсы аналитики выбрать

Сегодня мы поговорим о том, как выбрать лучшие курсы Power BI в Украине, особенно для…

13.01.2024

Work.ua назвал самые конкурентные вакансии в IТ за 2023 год

В 2023 году во всех крупнейших регионах конкуренция за вакансию выросла на 5–12%. Не исключением…

08.12.2023

Украинская IT-рекрутерка создала бесплатный трекер поиска работы

Unicorn Hunter/Talent Manager Лина Калиш создала бесплатный трекер поиска работы в Notion, систематизирующий все этапы…

07.12.2023

Mate academy отправит работников в 10-дневный оплачиваемый отпуск

Edtech-стартап Mate academy принял решение отправить своих работников в десятидневный отпуск – с 25 декабря…

07.12.2023

Переписки, фото, история браузера: киевский программист зарабатывал на шпионаже

Служба безопасности Украины задержала в Киеве 46-летнего программиста, который за деньги устанавливал шпионские программы и…

07.12.2023

Как вырасти до сеньйора? Девелопер создал популярную подборку на Github

IT-специалист Джордан Катлер создал и выложил на Github подборку разнообразных ресурсов, которые помогут достичь уровня…

07.12.2023