Нужно отобрать события ровно за вчерашний календарный день по created_at типа timestamp, чтобы не задвоить границы при ежедневном запуске. Какое условие в WHERE лучше?
A
WHERE created_at >= current_timestamp - INTERVAL '24 hours' AND created_at < current_timestampB
WHERE created_at > current_date - INTERVAL '1 day' AND created_at <= current_dateC
WHERE created_at >= current_date - INTERVAL '1 day' AND created_at < current_dateD
WHERE created_at BETWEEN current_date - INTERVAL '1 day' AND current_dateПравильный ответ. Для календарного дня используйте полуинтервал
[start, end) на базе current_date.Разбор
Удобнее задавать границы как created_at >= start AND created_at < end. Тогда событие ровно на границе (например, в 00:00:00) попадёт только в один день и не будет задваиваться, в отличие от BETWEEN, который включает обе границы.
Проверь себя · 1/3разбор после ответа
В таблице
events(user_id, created_at) колонка created_at типа timestamptz (события записаны в UTC). Нужно посчитать DAU по дням в таймзоне Москвы (и не зависеть от таймзоны сессии). Какой бакет правильный?Ещё вопросы по теме «Даты и время»
- В таблице `events(user_id, created_at)` поле `created_at` типа `timestamp`. Как посчитать количество событий по дням?
- Есть таблица `orders(created_at, amount)`, где `created_at` типа `timestamp`. Как посчитать выручку по месяцам?
- В таблице `events(created_at)` нужно выбрать события за последние 7 дней относительно текущего момента (`current_timestamp`). Какое условие в `WHERE` корректнее?
- Как получить начало текущей недели (недельный бакет) по текущей дате в PostgreSQL?
- Колонка `created_at` имеет тип `timestamp`. Какой тип данных вернёт `DATE_TRUNC('day', created_at)`?
- Все вопросы по «Даты и время» →