У меня есть запрос, который я сделал:
SELECT DISTINCT player_1 AS player,
(SELECT COUNT(*) FROM results WHERE player_1=player OR player_2=player) AS since_start_matches,
(SELECT COUNT(*) FROM results WHERE (player_1=player OR player_2=player) AND ht_total_goals=0) AS since_start_ht_0,
(SELECT COUNT(*) FROM results WHERE (player_1=player OR player_2=player) AND ht_total_goals=1) AS since_start_ht_1,
(SELECT COUNT(*) FROM results WHERE (player_1=player OR player_2=player) AND ht_total_goals=2) AS since_start_ht_2,
(SELECT COUNT(*) FROM results WHERE (player_1=player OR player_2=player) AND ht_total_goals=3) AS since_start_ht_3,
(SELECT COUNT(*) FROM results WHERE (player_1=player OR player_2=player) AND ht_total_goals=4) AS since_start_ht_4,
(SELECT COUNT(*) FROM results WHERE (player_1=player OR player_2=player) AND ht_total_goals>=5) AS since_start_ht_5_plus
FROM results ORDER BY player
Таблица results
содержит 25000 записей, и для выполнения этого запроса требуется около 7 секунд, что слишком долго. Запрос невероятно неэффективен, поскольку каждый создаваемый мной столбец снова выполняет поиск в той же таблице, но с другими условиями.
Я попытался проиндексировать интересующие столбцы в моем предложении where. Это сбивает пару секунд. Но он по-прежнему слишком медленный.
Как лучше всего обрабатывать такой запрос?
Я использую MariaDB 10.2