Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
05.02.2001, 17:10
|
|||
---|---|---|---|
|
|||
Заковыристый запрос (+) |
|||
#18+
Привет! Хотелось бы узнать у знающих людей - как на T-SQL написать запрос, который бы подсчитывал количество значений в нескольких полях (отдельно для каждого поля), отвечающих определенному условию (условие одно для всех полей - >0)? Другими словами, можно ли для каждой функции Count() поставить отдельный Where? Или цикл сделать как-то можно? Заранее спасибо! ... |
|||
:
Нравится:
Не нравится:
|
|||
|
05.02.2001, 17:29
|
|||
---|---|---|---|
Заковыристый запрос (+) |
|||
#18+
если я правильно понял вопрос, можно написать как-нибудь так: select sum(case when условие1 then 1 else 0 end) count1, sum(case when условие2 then 1 else 0 end) count2 from ... ... |
|||
:
Нравится:
Не нравится:
|
|||
|
05.02.2001, 18:07
|
|||
---|---|---|---|
Заковыристый запрос (+) |
|||
#18+
В данном случае, если условие везде >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 Подобные конструкции можно слепить для любых условий на численные данные ... |
|||
:
Нравится:
Не нравится:
|
|||
|
|
start [/forum/topic.php?fid=46&tablet=1&tid=1827400]: |
0ms |
get settings: |
9ms |
get forum list: |
12ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
26ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
46ms |
get tp. blocked users: |
2ms |
others: | 245ms |
total: | 362ms |
0 / 0 |