SELECT grid.t5
,min(t."time") AS min_time
-- ,array_agg(extract(min FROM t."time")) AS 'players_on' -- optional
,avg(t.players) AS avg_players
,avg(t.servers) AS avg_servers
FROM (
SELECT generate_series(min("time")
,max("time"), interval '5 min') AS t5
FROM tbl
) grid
LEFT JOIN tbl t ON t."time" >= grid.t5
AND t."time" < grid.t5 + interval '5 min'
GROUP BY grid.t5
ORDER BY grid.t5;
Обяснете
-
Подзаявката
grid
създава един ред на всеки 5 минути от минимума до максимума на "time"
във вашата таблица. -
LEFT JOIN обратно към данните за нарязване на таблицата на 5-минутни интервали. Внимателно включете долна граница и изключване горна граница.
-
За да изпуснете 5-минутни интервали, където нищо не се е случило, използвайте
JOIN
на мястото наLEFT JOIN
. -
За да накарате вашите часове в мрежата да започват от 0:00, 5:00 и т.н., закръглете надолу
min("time")
вgenerate_series()
.
Повече обяснения в тези свързани отговори:
Групиране по интервали на данни
PostgreSQL:текущо преброяване на редове за заявка „по минути"
Настрана:не бих използвал time
като идентификатор. Това е запазена дума в стандартния SQL
и име на функция/тип в Postgres.