Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
CASE и как перобразовать NULL->0 ?
|
|||
|---|---|---|---|
|
#18+
Имееться запрос слудующего вида : SELECT a.a1, a.a2, b.b1-(SELECT SUM(m1) FROM m WHERE m2=a.a4 ... ) AS xx .... .... В запросе в нескольких пестах используються подзапросы возращающие данные для вычислений, но могут быть случаи когда они возращают NULL, в этом случае результат операции равен тоже NULL а надо везде кге возвращаеться NULL заменить его на 0 Вроде для этого надо использовать CASE но я не очень хорошо понимаю как им пользоваться : b.b1-CASE (SELECT SUM(m1) FROM m WHERE m2=a.a4 ... ) WHEN NULL THEN 0 ELSE (SELECT SUM(m1) FROM m WHERE m2=a.a4 ... ) AS xx такой вариант не очень мне нравиться два подзапроса получаеться ... или второй раз подзапрос выполняться не будет ? Можно ли сделать это както по другому ? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.06.2001, 12:52 |
|
||
|
CASE и как перобразовать NULL->0 ?
|
|||
|---|---|---|---|
|
#18+
смотри в BOL функцию COALESCE() ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.06.2001, 12:59 |
|
||
|
|

start [/forum/topic.php?fid=46&msg=32007335&tid=1826524]: |
0ms |
get settings: |
10ms |
get forum list: |
19ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
36ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
43ms |
get tp. blocked users: |
1ms |
| others: | 229ms |
| total: | 359ms |

| 0 / 0 |
