Главная страница
    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.005 c
1-26057
Димка
2002-04-25 18:45
2002.05.09
Как запретить кнопку


1-26102
com6
2002-04-26 16:50
2002.05.09
Помогите: Как отследить манипуляции мышью и работу на клавиатуре?


1-26112
KvORubin
2002-04-24 13:30
2002.05.09
Как в Image1 отобразить иконку файла ???


3-26024
slc_g@yandex.ru
2002-04-16 14:21
2002.05.09
Мастера, как записать файл BMP в blob поле


14-26227
McSimm
2002-04-01 11:30
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
Английский Французский Немецкий Итальянский Португальский Русский Испанский