Нужно получить колонку event_date типа date из created_at (тип timestamp) для JOIN с календарной таблицей по дате. Какое выражение подойдёт лучше всего?
A
created_at::dateB
DATE_TRUNC('day', created_at)C
EXTRACT(DAY FROM created_at)D
DATE_TRUNC('month', created_at)::dateПравильный ответ. Если нужен именно тип
date, используйте приведение ::date.Разбор
DATE_TRUNC('day', created_at) даёт начало дня, но возвращает timestamp. Для JOIN с календарём, где ключ обычно типа date, удобнее сразу получить created_at::date.
Проверь себя · 1/3разбор после ответа
Колонка
created_at имеет тип timestamp. Какой тип данных вернёт DATE_TRUNC('day', created_at)?Ещё вопросы по теме «Даты и время»
- В таблице `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)`?
- Все вопросы по «Даты и время» →