Назад к вопросам
СБЕР
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.
- Группируем по имени отдела.
Это соответствует приведённому в вопросе запросу и корректно решает задачу.