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;
Jelaskan
-
Subkueri
grid
menghasilkan satu baris untuk setiap 5 menit dari minimum hingga maksimum "time"
di meja Anda. -
KIRI GABUNG kembali ke tabel mengiris data dalam interval 5 menit. sertakan dengan hati-hati batas bawah dan kecualikan batas atas.
-
Untuk membuang slot 5 menit di mana tidak terjadi apa-apa, gunakan
JOIN
sebagai penggantiLEFT JOIN
. -
Agar waktu grid Anda dimulai pada 0:00, 5:00 dll, bulatkan
min("time")
digenerate_series()
.
Penjelasan lebih lanjut dalam jawaban terkait ini:
Kelompokkan menurut interval data
PostgreSQL:menjalankan hitungan baris untuk kueri 'menurut menit'
Selain:Saya tidak akan menggunakan time
sebagai pengenal. Ini adalah kata yang dicadangkan dalam SQL standar
dan nama fungsi / ketik di Postgres.