Sobes.tech
Назад к вопросам
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.