Есть таблица orders(created_at, amount), где created_at типа timestamp. Как посчитать выручку по месяцам?
A
SELECT DATE_TRUNC('month', created_at) AS m, amount FROM orders GROUP BY m;B
SELECT DATE_TRUNC('month', created_at) AS m, SUM(amount) FROM orders;C
SELECT DATE_TRUNC('month', created_at) AS m, SUM(amount) FROM orders GROUP BY DATE_TRUNC('month', created_at);D
SELECT DATE_TRUNC('day', created_at) AS m, SUM(amount) FROM orders GROUP BY DATE_TRUNC('month', created_at);Правильный ответ. Для метрик по периодам вычислите бакет через
DATE_TRUNC и агрегируйте с GROUP BY по этому бакету.Разбор
Чтобы получить выручку по месяцам, сформируйте месячный бакет DATE_TRUNC('month', created_at) и посчитайте SUM(amount). В GROUP BY нужно повторить то же выражение, что используется для бакета.
Проверь себя · 1/3разбор после ответа
Нужно отобрать события ровно за вчерашний календарный день по
created_at типа timestamp, чтобы не задвоить границы при ежедневном запуске. Какое условие в WHERE лучше?Ещё вопросы по теме «Даты и время»
- В таблице `events(user_id, created_at)` поле `created_at` типа `timestamp`. Как посчитать количество событий по дням?
- В таблице `events(created_at)` нужно выбрать события за последние 7 дней относительно текущего момента (`current_timestamp`). Какое условие в `WHERE` корректнее?
- Как получить начало текущей недели (недельный бакет) по текущей дате в PostgreSQL?
- Колонка `created_at` имеет тип `timestamp`. Какой тип данных вернёт `DATE_TRUNC('day', created_at)`?
- В таблице `events(user_id, created_at)` колонка `created_at` типа `timestamptz` (события записаны в UTC). Нужно посчитать DAU по дням в таймзоне Москвы (и не зависеть от таймзоны сессии). Какой бакет правильный?
- Все вопросы по «Даты и время» →