В таблице events(user_id, created_at) поле created_at типа timestamp. Как посчитать количество событий по дням?

ASELECT created_at, COUNT(*) FROM events GROUP BY created_at;
BSELECT DATE_TRUNC('day', created_at) AS day, COUNT(*) FROM events GROUP BY DATE_TRUNC('day', created_at);
CSELECT DATE_TRUNC('day', created_at) AS day, COUNT(*) FROM events;
DSELECT DATE_TRUNC('month', created_at) AS day, COUNT(*) FROM events GROUP BY DATE_TRUNC('month', created_at);
Правильный ответ. DATE_TRUNC('day', ...) обрезает время до начала дня и подходит для группировки по дням.

Разбор

Для бакетирования по дням используйте DATE_TRUNC('day', created_at) и группируйте по этому же выражению. Группировка по самому created_at даст отдельную группу на каждую уникальную метку времени.

Проверь себя · 1/3разбор после ответа
Нужно отобрать события ровно за вчерашний календарный день по created_at типа timestamp, чтобы не задвоить границы при ежедневном запуске. Какое условие в WHERE лучше?
Тренировать SQL в Telegram

Ещё вопросы по теме «Даты и время»