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

Вниз

Логическая ошибка в триггере   Найти похожие ветки 

 
}|{yk ©   (2004-05-07 11:12) [0]

На insert и update срабатывает нормально, а на delete - устанавливает значение в null

AS
declare variable out_free_cash double precision;
begin
if (inserting or updating) then
 begin
select a.left_to_raspr from get_free_cash(new.plat_id) a into :out_free_cash;
update app_plateg a set a.free_cash=:out_free_cash where a.plat_id=new.plat_id;
 end
if (deleting) then
  begin
select a.left_to_raspr from get_free_cash(old.plat_id) a into :out_free_cash;
update app_plateg a set a.free_cash=:out_free_cash where a.plat_id=old.plat_id;
 end


 
Reindeer Moss Eater ©   (2004-05-07 11:15) [1]

После селекта в ветке удаления параметр принимает значение null


 
Курдль ©   (2004-05-07 11:17) [2]

А он after или before?


 
}|{yk ©   (2004-05-07 11:19) [3]

Триггер after insert, update, delete

Функция get_free_cash(new.plat_id)
begin
 select a.plat_sum from app_plateg a where a.plat_id=:inplat_id into :fullsumm;
 select sum(a.summa) from app_bank a where a.plat_id=:inplat_id into :already_raspr;
 left_to_raspr=:fullsumm-:already_raspr;
 suspend;
end


 
Курдль ©   (2004-05-07 11:28) [4]

А что показывает трассировка триггера?


 
}|{yk ©   (2004-05-07 11:38) [5]

Все, решил
Нужно было
 select coalesce(sum(a.summa),0) from app_bank a where a.plat_id=:inplat_id into :already_raspr;
иначе мог возвращаться null



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

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

Наверх




Память: 0.47 MB
Время: 0.027 c
14-1084478733
Черный прапорщик
2004-05-14 00:05
2004.05.30
Сабж


1-1083911503
andrey__
2004-05-07 10:31
2004.05.30
TServiceApplication - организация интерфейса


3-1084274477
bushmen
2004-05-11 15:21
2004.05.30
Знающим MySQL


14-1084192555
evvcom
2004-05-10 16:35
2004.05.30
Отдых в Украине


1-1084609118
Delphir
2004-05-15 12:18
2004.05.30
LowerCase по русски