Sobes.tech
Back to questions
Senior
8

Вопрос 9. Написать запрос, который вернет сотрудников, обладающих максимальной зарплатой в своей должности. Перейти на onecompiler.com/postgresql Скрипт для инициализации: CREATE TABLE users ( fio TEXT NOT NULL, position TEXT, salary BIGINT NOT NULL ); INSERT INTO users(fio, position, salary) VALUES ('Иванов', 'Тестировщик', 100000), ('Горохов', 'Тестировщик', 120000), ('Петров', 'Тестировщик', 140000), ('Сидоров', 'Тестировщик', 100000), ('Кузнецов', 'Тестировщик', 120000), ('Михайлов', 'Тестировщик', 150000), ('Антонов', 'Разработчик', 200000), ('Сухой', 'Разработчик', 100000), ('Микоян', 'Разработчик', 100000), ('Капустин', 'Директор', 300000), ('Астахов', 'ИБ', 200000); Пример результата: Михайлов Тестировщик 150000 Антонов Разработчик 200000 Капустин Директор 300000 Астахов ИБ 200000 Время на выполнение 10 минут. Скрипт запроса вписать в поле:

Companies where asked
Альфа-БанкАльфа-Банк

Answer from AI

sobes.tech AI

Для получения сотрудников с максимальной зарплатой в каждой должности можно использовать оконную функцию RANK() или подзапрос с агрегатной функцией MAX().

Пример с подзапросом:

SELECT fio, position, salary
FROM users u
WHERE salary = (
    SELECT MAX(salary)
    FROM users
    WHERE position = u.position
);

Этот запрос для каждой строки таблицы users сравнивает зарплату с максимальной зарплатой по той же должности и возвращает только тех сотрудников, у которых зарплата максимальна в своей должности.