Назад к вопросам
СБЕР
Senior
4
-- Есть таблицы со структурой Employee id (PK) name salary dep_id(FK department.id) Department id (PK) name -- написать запрос, который вернет список наименований всех отделов с максимальной зарплатой в каждом отделе select d.name, MAX(e.salary) from Department d left join Employee e on e.dep_id = d.id group by d.name
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Ваш SQL-запрос почти корректен, но чтобы получить максимальную зарплату для каждого отдела вместе с названием отдела, лучше группировать по идентификатору отдела и его имени, чтобы избежать проблем с дублированием или некорректной агрегацией.
Правильный запрос:
SELECT d.name, MAX(e.salary) AS max_salary
FROM Department d
LEFT JOIN Employee e ON e.dep_id = d.id
GROUP BY d.id, d.name
Объяснение:
- Используем LEFT JOIN, чтобы включить отделы без сотрудников (в этом случае max_salary будет NULL).
- Группируем по уникальному идентификатору отдела и его имени.
- Функция MAX(e.salary) возвращает максимальную зарплату в каждом отделе.
Если нужно исключить отделы без сотрудников, можно использовать INNER JOIN вместо LEFT JOIN.