Похоже, что временное окно для вашего запроса зависит от верхнего диапазона, указанного в предложении WHERE
. Поскольку прошло 15 минут после часа, вы можете попытаться агрегировать со смещением времени на 45 минут:
SELECT
MAX(time) AS time,
COUNT(*) AS ticks
FROM sensorticks
WHERE time BETWEEN (TIMESTAMP'2019-01-04 00:15:00') AND (TIMESTAMP'2019-01-04 14:15:00')
GROUP BY date_trunc('hour', time + interval '45 minutes')
ORDER BY time DESC;
Но в приведенном выше запросе все еще есть проблема, поскольку отображаемое время все еще может быть неправильным. Кроме того, некоторые временные интервалы могут отсутствовать, но вы все равно можете сообщить о них. Чтобы это исправить, мы можем попробовать использовать таблицу календаря:
WITH calendar AS (
SELECT TIMESTAMP '2019-01-04 14:00:00' AS ts, TIMESTAMP '2019-01-04 14:14:59' AS display UNION ALL
SELECT TIMESTAMP '2019-01-04 13:00:00', TIMESTAMP '2019-01-04 13:14:59' UNION ALL
SELECT TIMESTAMP '2019-01-04 12:00:00', TIMESTAMP '2019-01-04 12:14:59' UNION ALL
SELECT TIMESTAMP '2019-01-04 11:00:00', TIMESTAMP '2019-01-04 11:14:59' UNION ALL
SELECT TIMESTAMP '2019-01-04 10:00:00', TIMESTAMP '2019-01-04 10:14:59'
)
Затем мы можем присоединиться к этой календарной таблице, используя оригинальный запрос:
SELECT
c.display AS time,
COUNT(*) AS ticks
FROM calendar c
LEFT JOIN sensorticks s
ON c.ts = date_trunc('hour', s.time + interval '45 minutes')
WHERE s.time BETWEEN (TIMESTAMP'2019-01-04 00:15:00') AND (TIMESTAMP'2019-01-04 14:15:00')
GROUP BY c.display
ORDER BY c.display DESC;