Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Скорость выполнения запроса... / 2 сообщений из 2, страница 1 из 1
30.10.2003, 19:46
    #32311033
Sanych
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Скорость выполнения запроса...
Есть такой вот запрос:

SELECT Extensions.ExtensionNumber AS ExtensionName, COUNT( Calls.ID ) AS Quantity, SUM( Calls.Duration ) AS Duration, SUM( Calls.CallCost ) AS Cost
FROM Extensions
LEFT JOIN Calls ON (Calls.OriginationNumber=Extensions.ExtensionNumber OR Calls.DestinationNumber=Extensions.ExtensionNumber )
GROUP BY Extensions.ExtensionNumber ORDER BY Cost

Поля Calls.OriginationNumber, Calls.DestinationNumber и Extensions.ExtensionNumber индексированы.

В таблице Calls примерно 9000 записей.
В таблице Extensions - 40 записей.

Время выполнения такого запроса, у меня на машинке, примерно 13 секунд.
Если убрать одно из условий или поставить AND вместо OR в условии LEFT JOIN , время выполнения запроса будет меньше 0.5 секунды. Результат, конечно же будет неправильный.

Подскажите, пожалуйста, как ускорить время выполнения этого запроса.
...
Рейтинг: 0 / 0
30.10.2003, 21:39
    #32311098
Макс М.
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Скорость выполнения запроса...
почитай доку на тему EXPLAIN
И вообще в мануале целый раздел по оптимизации mysql
...
Рейтинг: 0 / 0
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Скорость выполнения запроса... / 2 сообщений из 2, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]