Нужно получить 10 последних событий конкретного пользователя (user_id = 42) из таблицы events. Какой запрос корректнее всего решает задачу?
A
SELECT event_time, event_name FROM events WHERE user_id = 42 ORDER BY event_time DESC LIMIT 10B
SELECT event_time, event_name FROM events ORDER BY event_time DESC LIMIT 10C
SELECT event_time, event_name FROM events WHERE user_id = 42 ORDER BY event_time ASC LIMIT 10D
SELECT event_time, event_name FROM events WHERE user_id = 42 LIMIT 10Правильный ответ. Чтобы получить «последние N» по пользователю, нужна и фильтрация в
WHERE, и сортировка в ORDER BY, и ограничение через LIMIT.Разбор
Если не указать WHERE user_id = 42, вы получите события всех пользователей. Если сортировать ASC, вы получите самые ранние события, а не последние. Если убрать ORDER BY, то LIMIT 10 вернёт произвольные 10 строк пользователя без гарантии, что они последние. Поэтому правильный паттерн: WHERE ... ORDER BY ... DESC LIMIT ....
Проверь себя · 1/3разбор после ответа
В таблице
users email хранится в разном регистре: 'Anna@mail.ru', 'anna@MAIL.ru' и т.д. Как надёжнее всего найти все записи с конкретным адресом вне зависимости от регистра?Ещё вопросы по теме «Основы 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-запросов» →