@DERBIAGLOBALISTO

В чём может быть причина очень долгого выполнения запроса?

select
				c.id,
				c.name,
				(select
					sum(uc.health) + sum(uc.power) + sum(uc.agil) + sum(uc.intell)
				from users_combat uc
				where id_user in(select cp.id_user from clan_part cp where cp.id_clan = c.id)) as score
			from clan c
			order by score desc
			limit 0, 10


В чём здесь может быть проблема? Заранее благодарен.
  • Вопрос задан
  • 66 просмотров
Решения вопроса 1
Rsa97
@Rsa97
Для правильного вопроса надо знать половину ответа
Проблема во вложенном подзапросе.
SELECT `c`.`id`, `c`.`name`, `s`.`score`
  FROM (
    SELECT `cp`.`id_clan` AS `id_clan`, 
           SUM(`uc`.`health`) + SUM(`uc`.`power`) 
           + SUM(`uc`.`agil`) + SUM(`uc`.`intell`) AS `score`
      FROM `clan_part` AS `cp` 
      JOIN `users_combat` AS `uc` ON `uc`.`id_user` = `cp`.`id_user`
      GROUP BY `cp`.`id_clan`
      ORDER BY `score` DESC
      LIMIT 0, 10
  ) AS `s`
  JOIN `clan` AS `c` ON `c`.`id` = `s`.`id_clan`
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы