Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 22.01.2016, 16:42
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание Помогите разобратся с запросом

Всем привет
есть база BASE в нем столбец где указано должности(сантехник, маляр, менеджер) сотрудников
как написать SQL запрос чтоб на экран вывести список людей чье количество больше в зависимости от должности

по запросу
select doljnost, count(*) as Count from BASE group by doljnost
получаю результать

Менеджер - 10
Сантехник - 12
Маляр - 14

как можно реализовать запрос одной строкой чтоб вывести на экран тех чье количество больше в зависимости от должности?
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #2  
Старый 22.01.2016, 18:34
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Если я правильно понял, то вам нужно просто отсортировать по убыванию выборку:
Код:
select doljnost, count(*) as Cnt from BASE group by doljnost order by Cnt desc
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 22.01.2016, 19:01
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

нет не совсем
нужно узнать на какой должности работают больше всех сотрудников
и выводить на экран их имена

я только начал изучать SQL а задачу препод поставил такую

select * from BASE // выводим все столбики

select doljnost, count(*) as cnt from BASE group by doljnost // оставляет только столбик должность и CNT
а чтоб узнать в какой должности работают больше всех сотрудников нужно получить доступ к максимальной значении CNT и
select max(cnt) from (select doljnost, count(*) as cnt from BASE group by doljnost) // возвращает результат где уже только одно значение
и появляется вопрос - возможно ли в одной строке совершить все процедуру??
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #4  
Старый 22.01.2016, 19:50
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Можно и одно строкой, но не одним запросом. Вложенный запрос придется использовать:
Код:
SELECT Sotrudnik
FROM Base where Doljnost = (select top 1 Doljnost from Base group by Doljnost order by Count(Doljnost) desc);
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
Electronic_Arts (22.01.2016)
  #5  
Старый 22.01.2016, 19:53
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Wow как это сработало

а что означает TOP 1 ?
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #6  
Старый 22.01.2016, 20:04
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Я столько литературы пролистал в сети про SQL но ни где не видел это по этому спрашиваю...просто сейчас заметил что если его не ставить то выдает ошибку
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #7  
Старый 22.01.2016, 20:16
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,057
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Top 1 означает, что надо вернуть одну запись от начала результата. Если его убрать, то получится, что ты сравниваешь поле со списком значений, что, естественно, приводит к ошибке. Проблема в том, что именно эта конструкция разная у разных БД.
Ответить с цитированием
Этот пользователь сказал Спасибо lmikle за это полезное сообщение:
Electronic_Arts (22.01.2016)
  #8  
Старый 22.01.2016, 20:17
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Хорошо

Спасибо ребята!
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #9  
Старый 22.01.2016, 20:30
Аватар для Admin
Admin Admin вне форума
Администратор
 
Регистрация: 03.10.2005
Адрес: Россия, Москва
Сообщения: 1,534
Версия Delphi: Delphi 7
Репутация: выкл
По умолчанию

Цитата:
Сообщение от Electronic_Arts
Я столько литературы пролистал в сети про SQL но ни где не видел это по этому спрашиваю...просто сейчас заметил что если его не ставить то выдает ошибку
из справки

Цитата:
TOP используется только в СУБД MS SQL Server. Аналогом в MySQL является оператор SQL LIMIT.
Ответить с цитированием
Этот пользователь сказал Спасибо Admin за это полезное сообщение:
Electronic_Arts (22.01.2016)
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 00:44.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter