Гость
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Заковыристый запрос (+) / 4 сообщений из 4, страница 1 из 1
05.02.2001, 17:10
    #32001979
Andy
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Заковыристый запрос (+)
Привет!
Хотелось бы узнать у знающих людей - как на T-SQL написать запрос, который бы подсчитывал количество значений в нескольких полях (отдельно для каждого поля), отвечающих определенному условию (условие одно для всех полей - >0)?
Другими словами, можно ли для каждой функции Count() поставить отдельный Where? Или цикл сделать как-то можно?
Заранее спасибо!
...
Рейтинг: 0 / 0
05.02.2001, 17:29
    #32001981
SergSuper
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Заковыристый запрос (+)
если я правильно понял вопрос, можно написать как-нибудь так:

select sum(case when условие1 then 1 else 0 end) count1,
sum(case when условие2 then 1 else 0 end) count2
from ...
...
Рейтинг: 0 / 0
05.02.2001, 18:07
    #32001983
dmitry
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Заковыристый запрос (+)
В данном случае, если условие везде >0, то можно и так:
Select sum(sign(field1*(sign(field1)+1))), sum(sign(field2*(sign(field2)+1)))from Tablename
Тут если fieldn<0, то sign(fieldn)+1=0 ,
если fieldn=0, то понятно.
Таким образом если fieldn<=0, то fieldn*(sign(fieldn)+1) будет равно 0 и sign от всего этого тоже 0
Если же fieldn>0, то fieldn*(sign(fieldn)+1)=fieldn и sign от него =1

Если же заранее известно, что все значения в таблице неотрицательные, то еще проще:
Select sum(sign(field1)), sum(sign(field2)) from Tablename

Подобные конструкции можно слепить для любых условий на численные данные
...
Рейтинг: 0 / 0
05.02.2001, 18:09
    #32001984
Andy
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Заковыристый запрос (+)
Ух! Вот это скорость! (имеется в виду ответ )
Спасибо огромное!
...
Рейтинг: 0 / 0
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Заковыристый запрос (+) / 4 сообщений из 4, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]