Вы сортируете товары по величине скидки discount по убыванию. discount может быть NULL (скидки нет). Чтобы товары без скидки всегда были внизу независимо от настроек СУБД, какой вариант сортировки выбрать?
A
ORDER BY discount DESC LIMIT 100B
ORDER BY discount DESC OFFSET 0C
ORDER BY discount DESC NULLS LASTD
ORDER BY discount DESC WHERE discount IS NOT NULLПравильный ответ.
NULLS FIRST / NULLS LAST позволяют явно зафиксировать позицию NULL при сортировке.Разбор
Поведение NULL при сортировке может отличаться между системами, поэтому для отчётов лучше задавать его явно. Если NULL означает «нет скидки» и должен быть внизу, добавьте NULLS LAST: ORDER BY discount DESC NULLS LAST. LIMIT и OFFSET не управляют положением NULL, а WHERE используется для фильтрации, а не для сортировки.
Проверь себя · 1/3разбор после ответа
Что сделает запрос
INSERT INTO archive (order_id, amount, status) SELECT order_id, amount, status FROM orders WHERE status = 'completed'?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям вам нужны только `user_id` и `signup_at` из таблицы `users`. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Вы строите выдачу «последние заказы» и используете `LIMIT 50`. Поле `created_at` не уникально (много заказов в одну секунду). Какой `ORDER BY` лучше, чтобы порядок был детерминированным?
- Что можно корректно утверждать про результат запроса `SELECT user_id FROM users LIMIT 10`, если в запросе нет `ORDER BY`?
- Все вопросы по «Основы SQL-запросов» →