Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
0 / 0 / 0
Регистрация: 13.05.2015
Сообщений: 45

Для каждой должности вывести только одного работника с наибольшим стажем

07.06.2015, 13:11. Показов 2163. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите, пожалуйста, как вывести для каждой должности только одного работника с наибольшим стажем? Вот код, но выводятся все работники, а не с наибольшим стажем.

MySQL
1
2
3
4
5
6
7
8
9
10
11
SELECT office.Specialty,
SUM(YEAR(workers.datend) - YEAR(workers.datr)) AS expr1,
worker.SecondName
FROM workers
INNER JOIN office
ON workers.idof = office.id_office
INNER JOIN worker
ON workers.idw = worker.id
GROUP BY workers.idof,
office.Specialty,
worker.SecondName
Миниатюры
Для каждой должности вывести только одного работника с наибольшим стажем  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.06.2015, 13:11
Ответы с готовыми решениями:

Функция подсчета стажа работника на должности
Конфа ЗУП(2.5.33.3 беларусь), запросом пытался подсчитать стаж из регистра "работникиОрганизации" но все осложняют поля...

Определить, какая заработная плата работника с самым большим стажем работы
Даны два одномерных массива х и у, где i = 1, 2, n. В массиве х задано стаж работников некоторого предприятия, а в массиве y -...

Определить максимальный и минимальный стаж для сотрудников каждой должности и пола
Прикладываю файл с начатым выполнением, помогите дальше сделать 25. Определить максимальный и минимальный стаж для сотрудников каждой...

4
 Аватар для Eur93
47 / 47 / 24
Регистрация: 16.09.2013
Сообщений: 349
07.06.2015, 15:08
valexab,

SQL
1
2
3
4
5
6
7
SELECT *
FROM workers AS `t1`
INNER JOIN office t3
ON t1.idof = t3.id_office
INNER JOIN worker
ON t1.idw = worker.id,
(SELECT `Specialty`,MAX(YEAR(workers.datend) - YEAR(workers.datr))AS`expr1`FROM workers INNER JOIN office ON workers.idof = office.id_office INNER JOIN worker ON workers.idw = worker.id GROUP BY`Specialty`)AS`t2` WHERE `t3`.`Specialty`=`t2`.`Specialty` AND YEAR(t1.datend) - YEAR(t1.datr)=`t2`.`expr1`
0
0 / 0 / 0
Регистрация: 13.05.2015
Сообщений: 45
07.06.2015, 15:43  [ТС]
А если один и тот же работник работал на одной и той же специальности но в разные периоды, как сложить его стаж?
0
 Аватар для Eur93
47 / 47 / 24
Регистрация: 16.09.2013
Сообщений: 349
08.06.2015, 01:05
Лучший ответ Сообщение было отмечено valexab как решение

Решение

valexab,

SQL
1
SELECT * FROM workers AS `t1` INNER JOIN office t3 ON t1.idof = t3.id_office INNER JOIN worker ON t1.idw = worker.id, (SELECT `Specialty`,MAX(`sum`)AS`expr1` FROM (SELECT *, SUM(YEAR(t1.datend) - YEAR(t1.datr))AS`sum` FROM workers AS `t1` INNER JOIN office t3 ON t1.idof = t3.id_office INNER JOIN worker ON t1.idw = worker.id GROUP BY `idw`)AS t7 GROUP BY `Specialty`) AS t2 WHERE `t3`.`Specialty`=`t2`.`Specialty` GROUP BY `idw` HAVING SUM(YEAR(t1.datend) - YEAR(t1.datr))=`t2`.`expr1`
1
0 / 0 / 0
Регистрация: 13.05.2015
Сообщений: 45
08.06.2015, 06:37  [ТС]
Спасибо большое! Помогло, немножко изменила и все получилось!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.06.2015, 06:37
Помогаю со студенческими работами здесь

В каждой строке для всех слов, которые встречаются в строке больше одного раза, оставить только первое вхождение
Народ, помогите Нужно в каждой строке для всех слов, которые встречаются в строке больше одного раза, оставить только первое вхождение.

Вывести идентификатор работника, имя и среднемесячную зарплату для всех элементов списка
Доброго времени суток! Есть такая задача: Построить три класса (базовый и 2 наследника), которые описывают некоторых работников...

Посчитать количество мужчин и женщин на каждой должности в одном запросе
Есть 2 таблицы, таблица Контакти и таблица Робота. в таблице контакты есть поле роботаИД и гендерИД(пол) нужно посчитать количество...

Реальная задачка с турнира по программированию. Вход только со стажем от трех лет!
Задача (под кодовой буквой I) для гурманов. Маленький Петя хочет сесть на переднее сиденье авомобиля. Но Степа, водитель, знает ПДД, а...

Определить объем товарооборота, приходящийся на одного работника
Условие задачи: Решить задачу, связанную с оценкой экономической деятельности группы предприятий на основе известных данных: Название...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru