Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.05.09;
Скачать: [xml.tar.bz2];

Вниз

Как привести NULL к нулю в SQL запросе?   Найти похожие ветки 

 
Alexander Vasjuk   (2002-04-15 12:10) [0]

Насчет хранимых процедур все понятно (if (x IS NULL) then x = 0)
А вот в рамках одного запроса!
Вот конкретная проблема

select
Name,
(select sum(Price * Kol) from Prihod where Tovar = Tovar.ID) -
(select sum(Price * Kol) from Rashod where Tovar = Tovar.ID) Ostatok
from Tovar
order by Name

В примере при отсуствии записей в таблице Rashod c полем Tovar, равным полю ID таблицы Tovar, разница сумм будет NULL, как и вычитаемая сумма.
Как бы в рамках одного запроса заставить SUM выдавать 0 вместо NULL для случая, когда суммировать нечего?


 
Val   (2002-04-15 12:14) [1]

функция NVL


 
Alexandr   (2002-04-15 12:14) [2]

ага.
Юзай UDF
в Rfunc есть функция Z. Делает как раз то, что тебе надо.


 
Val   (2002-04-15 12:18) [3]

сорри, не обратил внимания на БД :((


 
VAleksey   (2002-04-15 12:21) [4]

CAST


 
Johnmen   (2002-04-15 12:24) [5]

>VAleksey © : Не поможет !


 
SB.John   (2002-04-15 12:30) [6]

функция nvl если она есть в InterBase (наверняка какой-то аналог должен быть) ну иди на худой конец decode


 
Denbear   (2002-04-15 13:25) [7]

В MSSQL есть такая функция.
ISNULL() - это системная функция, которая возвращает строку символов или числа вместо (NULL), когда это значение встречается в сохраняемой структуре данных, такой как столбец таблицы. Синтаксис функции ISNULL(): ISNULL(выражение, значение)


 
Val   (2002-04-15 13:27) [8]

никто на тип бд не смотрит ;)


 
Alexandr   (2002-04-15 13:31) [9]

2Val:
Как это никто? Я смотрел. И дал ему правильный совет. Я сам так работаю.
Его запрос преобразится в вид

select
Name,
z(select sum(Price * Kol) from Prihod where Tovar = Tovar.ID) -
z(select sum(Price * Kol) from Rashod where Tovar = Tovar.ID) Ostatok
from Tovar
order by Name


и делов-то...


 
Alexander Vasjuk   (2002-04-15 13:41) [10]

Спасибо всем.
Да, похоже без UDF никак...
Пожалуй я все-таки через процедуру сделаю, чтоб потом у клиентом автоматом сработало, чтоб не лезть у них в сервер.
Да и против UDF у меня предубеждение. Не знаю, может эти глюки уже исправились, но раньше, к примеру, строковые функции глюкали на максимальной длине...


 
Val   (2002-04-15 13:41) [11]

>Alexandr © (15.04.02 13:31)
не относится это к вам совершенно :)
Ваш ответ и был-то единственным полезным



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

Форум: "Базы";
Текущий архив: 2002.05.09;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.006 c
14-26234
Keymaster
2002-03-24 01:31
2002.05.09
2 + 2 * 2 = ???


1-26133
Egor111
2002-04-24 17:36
2002.05.09
TThread


14-26225
SPeller
2002-04-01 11:31
2002.05.09
С праздником, дорогие товарищи !!!


3-26002
anp
2002-04-15 18:00
2002.05.09
Ошибка


7-26280
sammy
2002-02-12 08:19
2002.05.09
свойства файлов





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский