В таблице events(created_at) нужно выбрать события за последние 7 дней относительно текущего момента (current_timestamp). Какое условие в WHERE корректнее?
A
WHERE created_at >= current_timestamp - INTERVAL '7 days'B
WHERE created_at >= current_date - INTERVAL '7 days'C
WHERE DATE_TRUNC('day', created_at) >= current_timestamp - INTERVAL '7 days'D
WHERE created_at <= current_timestamp - INTERVAL '7 days'Правильный ответ. Для скользящего окна используйте
current_timestamp и вычитайте интервал через INTERVAL.Разбор
current_date обнуляет время до полуночи и подходит для календарных периодов. Для последних 7 дней относительно текущего момента используйте created_at >= current_timestamp - INTERVAL '7 days'.
Проверь себя · 1/3разбор после ответа
Для сравнения метрик по неделям нужно получить начало предыдущей недели. Какое выражение вернёт начало предыдущей недели относительно
current_date?Ещё вопросы по теме «Даты и время»
- В таблице `events(user_id, created_at)` поле `created_at` типа `timestamp`. Как посчитать количество событий по дням?
- Есть таблица `orders(created_at, amount)`, где `created_at` типа `timestamp`. Как посчитать выручку по месяцам?
- Как получить начало текущей недели (недельный бакет) по текущей дате в PostgreSQL?
- Колонка `created_at` имеет тип `timestamp`. Какой тип данных вернёт `DATE_TRUNC('day', created_at)`?
- В таблице `events(user_id, created_at)` колонка `created_at` типа `timestamptz` (события записаны в UTC). Нужно посчитать DAU по дням в таймзоне Москвы (и не зависеть от таймзоны сессии). Какой бакет правильный?
- Все вопросы по «Даты и время» →