В таблице событий поле updated_at может быть NULL (ещё не обработано). Нужно отсортировать так: сначала обработанные события по свежести обновления, затем необработанные внизу, и при одинаковом updated_at порядок должен быть стабильным по event_id. Какой ORDER BY соответствует этому?
A
ORDER BY updated_at DESC NULLS FIRST, event_id ASCB
ORDER BY updated_at DESC, event_id ASCC
ORDER BY updated_at DESC NULLS LASTD
ORDER BY updated_at DESC NULLS LAST, event_id ASCПравильный ответ. Сочетайте
NULLS LAST для положения пропусков и второй столбец в ORDER BY для стабильности при совпадениях.Разбор
Условие «сначала свежие обновления» означает updated_at DESC. Условие «пропуски внизу» означает NULLS LAST. Условие стабильного порядка при одинаковом updated_at означает добавление второго ключа сортировки, например event_id ASC. Без второго ключа порядок строк с одинаковым updated_at может меняться от запроса к запросу. Поэтому корректная сортировка: ORDER BY updated_at DESC NULLS LAST, event_id ASC.
Проверь себя · 1/3разбор после ответа
Таблицы
orders_2024 и orders_2025 имеют одинаковую структуру. Некоторые заказы случайно попали в обе таблицы. Чем будут отличаться результаты SELECT * FROM orders_2024 UNION SELECT * FROM orders_2025 и того же запроса с UNION ALL?Ещё вопросы по теме «Основы 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-запросов» →