Я играю в баскетбольную игру, которая позволяет выводить статистику в виде файла базы данных, чтобы можно было рассчитать статистику, которая не реализована в игре. До сих пор у меня не было проблем с вычислением статистики, которую я хотел, но теперь я столкнулся с проблемой: подсчитать количество двойных и / или тройных удвоений, сделанных игроком за сезон, из его игровой статистики.
Определение двойного двойного и тройного двойного следующее:
Пятислойный:
Дабл-дабл определяется как исполнение, в котором игрок накапливает в игре двузначное число в двух из пяти статистических категорий - очки, отдачи, передачи, перехваты и заблокированные удары.
Трипл-дабл:
Тройной дабл определяется как исполнение, в котором игрок накапливает в игре двузначное число в трех из пяти статистических категорий - очки, отскоки, передачи, перехваты и заблокированные удары.
Четырехместный-двойной (добавлено для уточнения)
Четверной дубль определяется как исполнение, в котором игрок накапливает двузначное число в четырех из пяти статистических категорий - очки, отдачи, передачи, перехваты и заблокированные удары - в игре.
Таблица «PlayerGameStats» хранит статистику для каждой игры, в которую играет игрок, и выглядит следующим образом:
CREATE TABLE PlayerGameStats AS SELECT * FROM ( VALUES
( 1, 1, 1, 'Nuggets', 'Cavaliers', 6, 8, 2, 2, 0 ),
( 2, 1, 2, 'Nuggets', 'Clippers', 15, 7, 0, 1, 3 ),
( 3, 1, 6, 'Nuggets', 'Trailblazers', 11, 11, 1, 2, 1 ),
( 4, 1, 10, 'Nuggets', 'Mavericks', 8, 10, 2, 2, 12 ),
( 5, 1, 11, 'Nuggets', 'Knicks', 23, 12, 1, 0, 0 ),
( 6, 1, 12, 'Nuggets', 'Jazz', 8, 8, 11, 1, 0 ),
( 7, 1, 13, 'Nuggets', 'Suns', 7, 11, 2, 2, 1 ),
( 8, 1, 14, 'Nuggets', 'Kings', 10, 15, 0, 3, 1 ),
( 9, 1, 15, 'Nuggets', 'Kings', 9, 7, 5, 0, 4 ),
(10, 1, 17, 'Nuggets', 'Thunder', 13, 10, 10, 1, 0 )
) AS t(id,player_id,seasonday,team,opponent,points,rebounds,assists,steals,blocks);
Результат, который я хочу получить, выглядит следующим образом:
| player_id | team | doubleDoubles | tripleDoubles |
|-----------|---------|---------------|---------------|
| 1 | Nuggets | 4 | 1 |
Единственное решение, которое я нашел до сих пор, так ужасно, что меня тошнит ...; о) ... Это выглядит так:
SELECT
player_id,
team,
SUM(CASE WHEN(points >= 10 AND rebounds >= 10) OR
(points >= 10 AND assists >= 10) OR
(points >= 10 AND steals >= 10)
THEN 1
ELSE 0
END) AS doubleDoubles
FROM PlayerGameStats
GROUP BY player_id
... и теперь вы, вероятно, тоже рвете (или сильно смеетесь) после прочтения этого. Я даже не выписал все, что нужно для получения всех двойных двойных комбинаций, и пропустил оператор case для тройных двойных комбинаций, потому что это еще более нелепо.
Есть лучший способ это сделать? Либо со структурой таблицы, которая у меня есть, либо с новой структурой таблицы (я мог бы написать скрипт для преобразования таблицы).
Я могу использовать MySQL 5.5 или PostgreSQL 9.2.
Вот ссылка на SqlFiddle с примерами данных и моим ужасным решением, которое я разместил выше: http://sqlfiddle.com/#!2/af6101/3
Обратите внимание, что меня не очень интересуют четверные-двойные числа (см. Выше), поскольку они не встречаются в игре, в которую я играю, насколько я знаю, но было бы плюсом, если запрос легко расширяется без особой перезаписи в аккаунт. для четырехместных.