Колонка created_at типа timestamp. Какое утверждение про created_at::date и DATE_TRUNC('day', created_at) верно?
A
created_at::date всегда возвращает timestamp, а DATE_TRUNC('day', created_at) — date.B
DATE_TRUNC('day', created_at) округляет время до ближайшего дня, а не обрезает.C
created_at::date возвращает тип date, а DATE_TRUNC('day', created_at) возвращает тип timestamp (с временем начала дня).DОба выражения всегда возвращают одинаковый тип данных.
Правильный ответ. Приведение
::date меняет тип, а DATE_TRUNC сохраняет timestamp и обнуляет время ниже указанной гранулярности.Разбор
При created_at::date вы получаете календарную дату без времени. DATE_TRUNC('day', created_at) возвращает timestamp на 00:00:00 этого дня. Это влияет на формат результата и на дальнейшие вычисления/сравнения.
Проверь себя · 1/3разбор после ответа
Колонка
created_at типа timestamptz. Таймзона сессии (TimeZone) может отличаться между задачами. Как гарантированно сгруппировать события по UTC-дням?Ещё вопросы по теме «Даты и время»
- В таблице `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)`?
- Все вопросы по «Даты и время» →