Колонка created_at имеет тип timestamp. Какой тип данных вернёт DATE_TRUNC('day', created_at)?
AТип
timestamp (время будет 00:00:00 для выбранного дня).BТип
date (только календарная дата без времени).CЦелое число — номер дня в месяце.
DСтроку в формате
YYYY-MM-DD.Правильный ответ.
DATE_TRUNC сохраняет тип timestamp и обнуляет более мелкие компоненты времени.Разбор
При входе типа timestamp результат DATE_TRUNC('day', created_at) тоже будет timestamp, просто с временем начала дня. Если нужен именно date, используйте приведение created_at::date.
Проверь себя · 1/3разбор после ответа
В таблице
users(signup_at) поле signup_at типа date. Нужно получить дату «через один календарный месяц» после регистрации. Какое выражение корректнее?Ещё вопросы по теме «Даты и время»
- В таблице `events(user_id, created_at)` поле `created_at` типа `timestamp`. Как посчитать количество событий по дням?
- Есть таблица `orders(created_at, amount)`, где `created_at` типа `timestamp`. Как посчитать выручку по месяцам?
- В таблице `events(created_at)` нужно выбрать события за последние 7 дней относительно текущего момента (`current_timestamp`). Какое условие в `WHERE` корректнее?
- Как получить начало текущей недели (недельный бакет) по текущей дате в PostgreSQL?
- В таблице `events(user_id, created_at)` колонка `created_at` типа `timestamptz` (события записаны в UTC). Нужно посчитать DAU по дням в таймзоне Москвы (и не зависеть от таймзоны сессии). Какой бакет правильный?
- Все вопросы по «Даты и время» →