Почему этот sql-запрос занимает много времени?

Этот запрос на веб-сайте OctoberCMS, созданном с помощью Laravel. Выполнение занимает около 580 мс! В чем проблема? и как его ускорить?

SELECT * 
FROM   system_files 
WHERE  system_files.attachment_type = 'Me\Articles\Models\Article' 
       AND system_files.attachment_id = '235017' 
       AND field = 'image' 
       AND system_files.attachment_id IS NOT NULL 
ORDER  BY sort_order ASC 
LIMIT  1 

В таблице около 220 000 записей, и это индексы в таблице:

field
attachment_id
attachment_type

попробуйте добавить индексы в поля where

dparoli 07.03.2019 22:36

Уже есть 3 индекса, я обновил вопрос с ними.

Behiry 07.03.2019 22:42

Это общая база данных или она находится под большой нагрузкой?

Travis Britz 07.03.2019 22:44

Вам не нужен system_files.attachment_id is not null, так как вы уже отфильтровываете его с помощью system_files.attachment_id = '235017'. Если это поле не является строкой, вы можете изменить его на system_files.attachment_id = 235017.

Asdfg 07.03.2019 22:45
dev.mysql.com/doc/refman/5.7/en/using-explain.html
Marcin Orlowski 07.03.2019 22:46

Вызывает ли ваше предложение ORDER BY сканирование таблицы?

Robert Harvey 07.03.2019 22:47
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
6
57
0

Другие вопросы по теме