Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.10.30;
Скачать: CL | DM;

Вниз

значение NULL в ХП   Найти похожие ветки 

 
nick-from ©   (2003-10-11 12:13) [0]

Сделал такую ХП на подсчет текущего количества товара:

CREATE PROCEDURE GETGOODSQUANTITY
(
aGoodsId INTEGER
)
RETURNS
(
Result INTEGER
)
AS
DECLARE VARIABLE aGoodsArrival INTEGER;
DECLARE VARIABLE aGoodsLeaving INTEGER;
BEGIN
SELECT SUM(Ga_Quantity) FROM GoodsArrival GA WHERE GA.Ga_GoodsId = :aGoodsId INTO :aGoodsArrival;
SELECT SUM(GE_Quantity) FROM GoodsExpense GE WHERE GE.GE_GoodsId = :aGoodsId INTO :aGoodsLeaving;
RESULT = :aGoodsArrival - :aGoodsLeaving;
SUSPEND;
END;

Проблема в том, что когда товар ни разу не продавался, записей в таблице GoodsExpense для него не будет, значит и сумма по GE_Quantity будет NULL. В этом случае и результат тоже будет NULL.

Как можно избежать этого, чтобы при :aGoodsLeaving равной NULL в эту переменную записывался 0 например? И результат был не NULL, а :aGoodsArrival - 0 = :aGoodsArrival

Можно ли написать в самой ХП такую проверку, типа: IF :aGoodsLeaving = NULL THEN ...?
У меня чего-то не получается.

Я эту проблему решил на клиенте так: Запускаются подряд два вышеописанных запроса в Query в контексте Snapshot. Потом сравниваем на NULL так: if Query.FieldByName["Sum"].IsNull Then var02 := 0 else var02 := Query.FieldByName["Sum"].AsInteger;
Так все прокатывает, но нужно сделать это на сервере в ХП.

Так вот, можно ли так сделать в самой ХП каким-либо образом?


 
Vlad ©   (2003-10-11 12:32) [1]

>Можно ли написать в самой ХП такую проверку, типа: IF :aGoodsLeaving = NULL THEN ...?

IF (:aGoodsLeaving IS NULL) THEN
BEGIN
END



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

Текущий архив: 2003.10.30;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.021 c
1-98638
KSergey
2003-10-17 14:28
2003.10.30
Про устройство компонента DBGrid


1-98731
Jiura23cfdf
2003-10-20 19:49
2003.10.30
Еще раз: как сохранить данные из RichEdit1 в RichEdit2?


1-98602
Эл
2003-10-19 14:08
2003.10.30
Зависимость форм от разрешения экрана


1-98579
Chuha
2003-10-20 10:43
2003.10.30
Части предложения


14-98876
Ketmar
2003-10-12 10:16
2003.10.30
DarkEyeProxy v0.2.1