sql >> Base de Datos >  >> RDS >> PostgreSQL

Tome las últimas 3 horas y agrupe por 5 minutos

Usa generate_series() :

SELECT gs.t, COUNT(t.createdts)
FROM GENERATE_SERIES(now()::date - interval '3 hour', now()::date, interval '5 minute') gs(t)
     mytable t
     ON t.createdts >= gs.t AND
        t.createdts < gs.t + interval '5 minute'
GROUP BY gs.t;