Что вернёт запрос SELECT e.name AS employee, m.name AS manager FROM employees e JOIN employees m ON e.manager_id = m.id?
AЗапрос вернёт ошибку, потому что нельзя использовать одну таблицу дважды в одном запросе
BЗапрос вернёт всех сотрудников, у которых есть подчинённые, без информации о руководителях
CЗапрос вернёт пары «сотрудник — его руководитель» благодаря псевдонимам
e и mDЗапрос вернёт каждого сотрудника дважды: один раз как сотрудника и один раз как руководителя
Правильный ответ. Псевдонимы позволяют обращаться к одной таблице как к двум разным источникам в одном запросе.
Разбор
Здесь таблица employees используется дважды: под псевдонимом e — как источник сотрудников, под псевдонимом m — как источник руководителей. Условие e.manager_id = m.id связывает каждого сотрудника с его руководителем. В результате получим пары «сотрудник — руководитель». Сотрудники без руководителя (manager_id IS NULL) не попадут в результат при обычном JOIN.
Проверь себя · 1/3разбор после ответа
Что произойдёт при выполнении запроса
SELECT product_id, price - cost AS margin FROM products, если столбцы price и cost числовые?Ещё вопросы по теме «Основы 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-запросов» →