Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Элементарный запрос mysql выполняется ужасно долго, Помогите оптимизировать 
V
    Опции темы
Ilfirin
  Дата 26.7.2012, 22:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Strider



Профиль
Группа: Участник
Сообщений: 29
Регистрация: 7.10.2008
Где: Surreal world

Репутация: нет
Всего: нет



Есть две таблицы:
клиенты - clients (id, name),
продажи - sales (id, client_id, price)

у каждого клиента может быть по несколько покупок, а может быть и ни одной.

Задача:

Вывести список клиентов и суммы их покупок.

Моё решение:
Делаю такой запрос:
Код

SELECT 
    clients.id, 
    clients.name,
  statics.total
FROM clients
LEFT JOIN
    (SELECT client_id, SUM( price ) as total FROM sales GROUP BY sales.client_id) AS statics 
ON statics.client_id = clients.id


Данный запрос при базе пользователей например (5к) и продаж (10к)
выполняется долго - 2-3 секунды.

В то время как отдельные его части как:
Код

SELECT client_id, SUM( price ) as total FROM sales GROUP BY sales.client_id


или весь запрос но без GROUP BY:

Код

SELECT 
    clients.id, 
    clients.name,
  statics.total
FROM clients
LEFT JOIN
    (SELECT client_id, 0 as total FROM sales) AS statics 
ON statics.client_id = clients.id


выполняется сотые доли секунды.

Вопрос:

Можно ли оптимизировать этот запрос чтобы он выполнялся быстро или нет?
PM ICQ   Вверх
Akina
Дата 28.7.2012, 23:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 45
Всего: 454



Код

SELECT
  clients.id
, clients.name
, SUM(sales.price) total
FROM
  clients 
LEFT JOIN
  sales
ON
  sales.client_id = clients.id
GROUP BY
  clients.id
, clients.name;



--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




[ Время генерации скрипта: 0.0811 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.