Нужно выбрать заказы за декабрь 2025 из таблицы заказов по полю created_at с временем. Какой фильтр надёжнее задаёт диапазон «весь месяц» без потерь по краям?
A
WHERE created_at = '2025-12-01' OR created_at = '2025-12-31'B
WHERE created_at >= '2025-12-01' AND created_at < '2026-01-01'C
WHERE created_at > '2025-12-01' AND created_at < '2025-12-31'D
WHERE created_at <= '2025-12-31' AND created_at >= '2025-12-15'Правильный ответ. Для «целого периода» удобно использовать полуинтервал:
>= начало и < следующий период.Разбор
Фильтр created_at >= '2025-12-01' AND created_at < '2026-01-01' захватывает все значения внутри декабря, включая время внутри дня (если created_at содержит время). Варианты с = или <= обычно либо слишком узкие, либо могут некорректно обработать время в конце дня. Вариант со строгими неравенствами теряет границы месяца — первое и последнее число.
Проверь себя · 1/3разбор после ответа
В запросе используется выражение:
SELECT user_id, CASE WHEN age < 18 THEN 'подросток' WHEN age < 30 THEN 'молодой' WHEN age < 50 THEN 'средний' ELSE 'старший' END AS сегмент FROM users. Пользователю 25 лет — какое значение он получит и почему?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям нужны только идентификатор пользователя `user_id` и дата `signup_at` из таблицы пользователей. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Вы строите выдачу «последние заказы» и используете `LIMIT 50`. Поле `created_at` не уникально (много заказов в одну секунду). Какой `ORDER BY` лучше, чтобы порядок был детерминированным?
- Что можно корректно утверждать про результат запроса `SELECT user_id FROM users LIMIT 10`, если в нём нет `ORDER BY`?
- Все вопросы по «Основы SQL-запросов» →