Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.03.17;
Скачать: CL | DM;

Вниз

Вопроc по SQL   Найти похожие ветки 

 
phantom2040 ©   (2003-02-25 16:26) [0]

Привет Мастера!!!
Интересует такой вопрос, есть таблица по передаче факсов, поля следующие 1 - "категория" - в нем информация типе передаваемого сообщения к примеру: служебный, население и т.д. , 2-"Тип вызова" - в нем информация о типе вызова: Междугородний, международный, 3 - "Количество листов" - в нем сколько листов передано, 4 - "Всего" - соответственно сумма уплаченная за передачу. Задача такая нужно рассортировать по категориям по первому полю, каждую категорию рассортировать по типу вызова, просчитать количество услуг в каждой категории, просуммировать количество листов, и просумировать поле всего для каждой категории.
Вопрос можно ли такое сделать средствами языка SQL, в принципе задача решена с помошью циклов и массивов, но интересно можно ли более рационально решить все это дело, так сказать одной строкой, я уже второй раз сталкиваюсь с такой задачей и все время приходится извращаться при помощи массивов и циклов????


 
Соловьев ©   (2003-02-25 16:29) [1]

group by и count тебе помогут


 
Johnmen ©   (2003-02-25 16:33) [2]

SELECT "категория", "Тип вызова", COUNT(*), SUM("Количество листов"), SUM("Всего")
FROM Table
GROUP BY "категория", "Тип вызова"


 
phantom2040 ©   (2003-02-26 08:57) [3]

Хотелось бы конечно заметить, что после построения запрсоса по указанному шаблону, DBD выдал следующее:
When GROUP BY exists, every simple field in projectors must be in GROUP BY
На сколько я понял из выше сказаенного, для группировки нужно одно поле, по нескольким полям групирровка не возможна.
Так как же быть????


 
Johnmen ©   (2003-02-26 09:20) [4]

Понял неправильно ! Группировать можно по сколько угодным полям, лишь бы все простые поля (не входящие в агрегирование) были перечислены в GROUP BY.


 
phantom2040 ©   (2003-02-26 09:29) [5]

(не входящие в агрегирование)
Это как понять???


 
Соловьев ©   (2003-02-26 09:36) [6]


> COUNT(*), SUM("Количество листов"), SUM("Всего")



 
Johnmen ©   (2003-02-26 09:40) [7]

Вообще-то для понимания читают книжки...:)))

SELECT F1, F2, COUNT(*), SUM(F3), MAX(F4)
здесь F1, F2 - простые поля (в смысле поля запроса !),
а поля COUNT(*), SUM(F3), MAX(F4) - поля агрегированные, т.е. представляющие собой агрегатные ф-ии.




 
phantom2040 ©   (2003-02-26 10:03) [8]

Спасибо вроде получилось


 
Stranger ©   (2003-02-27 09:40) [9]

Для сортировки можно использовать в запросе раздел
Order By



Страницы: 1 вся ветка

Текущий архив: 2003.03.17;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.019 c
3-53945
Choo
2003-02-26 15:07
2003.03.17
Репликация БД


14-54301
Злодей
2003-02-28 22:24
2003.03.17
Компоненты...


14-54268
Darts
2003-02-28 12:29
2003.03.17
Перлы Буша Без комментариев.


3-53955
vega77
2003-02-26 16:44
2003.03.17
stack overflow...


9-53837
Gandalf
2002-10-17 15:01
2003.03.17
Пишем DirectX-движок