Нужно получить 10 последних событий конкретного пользователя (user_id = 42) из таблицы events. Какой запрос корректнее всего решает задачу?

ASELECT event_time, event_name FROM events WHERE user_id = 42 ORDER BY event_time DESC LIMIT 10
BSELECT event_time, event_name FROM events ORDER BY event_time DESC LIMIT 10
CSELECT event_time, event_name FROM events WHERE user_id = 42 ORDER BY event_time ASC LIMIT 10
DSELECT 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 в Telegram

Ещё вопросы по теме «Основы SQL-запросов»