Sobes.tech
Назад к вопросам
Senior
3

-- Есть таблицы со структурой Employee id (PK) name salary dep_id(FK department.id) Department id (PK) name -- написать запрос, который вернет список наименований всех отделов с максимальной зарплатой в каждом отделе select d.name, COALESCE(MAX(e.salary), 0) from Department d left join Employee e on e.dep_id = d.id group by d.name

Компании, где спрашивали
СБЕРСБЕР

Ответ от нейросети

sobes.tech AI

Запрос, который возвращает список наименований всех отделов с максимальной зарплатой в каждом отделе, можно написать так:

SELECT d.name, COALESCE(MAX(e.salary), 0) AS max_salary
FROM Department d
LEFT JOIN Employee e ON e.dep_id = d.id
GROUP BY d.name

Объяснение:

  • Используем LEFT JOIN, чтобы включить все отделы, даже если в них нет сотрудников.
  • Функция MAX(e.salary) находит максимальную зарплату в отделе.
  • COALESCE заменяет NULL (если сотрудников нет) на 0.
  • Группируем по имени отдела.

Это соответствует приведённому в вопросе запросу и корректно решает задачу.