В таблице пользователей поле last_login может быть NULL (пользователь ни разу не заходил). Нужно отсортировать пользователей так, чтобы самые недавно заходившие были сверху, а пропущенные значения оказались внизу. Какая сортировка решает обе задачи?
A
ORDER BY last_login DESCB
ORDER BY last_login DESC NULLS FIRSTC
ORDER BY last_login ASC NULLS LASTD
ORDER BY last_login DESC NULLS LASTПравильный ответ. Явно указывайте положение пропусков в сортировке через
NULLS FIRST или NULLS LAST, чтобы не зависеть от дефолтов СУБД.Разбор
Нужно одновременно два требования: порядок по свежести (DESC) и размещение пропусков внизу (NULLS LAST). Поэтому корректно ORDER BY last_login DESC NULLS LAST. Если положение пропусков не указать явно, поведение зависит от СУБД и её настроек: где-то по умолчанию NULL идут в конец, где-то в начало. Для отчётов и витрин лучше задавать порядок явно, чтобы результат был предсказуемым.
Проверь себя · 1/3разбор после ответа
В таблице
users нужно выбрать только активных пользователей из России или Казахстана. Какой WHERE соответствует требованию?Ещё вопросы по теме «Основы 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-запросов» →