Что можно корректно утверждать про результат запроса SELECT user_id FROM users LIMIT 10, если в запросе нет ORDER BY?
ASQL не гарантирует, какие именно 10 строк вернутся без
ORDER BYBВсегда вернутся 10 самых ранних пользователей по
created_atCВсегда вернутся 10 самых новых пользователей по
created_atDЗапрос не выполнится:
LIMIT нельзя использовать без ORDER BYПравильный ответ. Без
ORDER BY порядок строк не определён, поэтому LIMIT ограничивает «первые N» в неопределённом порядке.Разбор
LIMIT сам по себе не выбирает «первые по времени» или «последние по id» — он просто берёт первые N строк из результата. Но если вы не задали ORDER BY, СУБД не обязана возвращать строки в одном и том же порядке. Поэтому при аналитических задачах (топ-N, списки, страницы) обычно всегда задают явную сортировку.
Проверь себя · 1/3разбор после ответа
Для отчёта по регистрациям вам нужны только
user_id и signup_at из таблицы users. Какой запрос лучше соответствует задаче и не тянет лишние поля?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям вам нужны только `user_id` и `signup_at` из таблицы `users`. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Вы строите выдачу «последние заказы» и используете `LIMIT 50`. Поле `created_at` не уникально (много заказов в одну секунду). Какой `ORDER BY` лучше, чтобы порядок был детерминированным?
- Нужно показать 3-ю страницу каталога товаров: по 20 товаров на страницу, сортировка по цене по возрастанию (`price`). Какой запрос корректный?
- Все вопросы по «Основы SQL-запросов» →