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

Вниз

Firebird, execute procedure   Найти похожие ветки 

 
Sheriff   (2004-08-30 15:49) [0]

Здарвствуйте. помогите разобраться с проблемой.
Попытка скомпилировать триггер вызывает ошибку:
Invalid token.
invalid request BLR at offset 46.
parameter mismatch for procedure CALCULATEVALUE.

CREATE TRIGGER TBL_INFO_AI0 FOR TBL_INFO
ACTIVE AFTER INSERT POSITION 0
AS
begin
execute procedure calculatevalue(new.parentid);
end

процедура работает правильно.
спасибо.


 
Reindeer Moss Eater ©   (2004-08-30 15:53) [1]

new в after insert есть разве?


 
Sheriff   (2004-08-30 15:59) [2]

так ведь после вставки в поле (в буфере) уже есть новое значение. или я что-то путаю?
в книге Мир Interbase указано, что контекстная переменная new доступна в типе триггера after insert.


 
Роман Снегирев   (2004-08-30 16:03) [3]

new в after insert есть разве?
new не используется только в тригерах Delete.
Вообще на первый взглад все должно работать, проверь тип данных передаваемого параметра


 
Sheriff   (2004-08-30 16:09) [4]

входной параметр типа integer, поле parentid типа integer.
да, процедура должна возвращать значение типа double precision.


 
Роман Снегирев   (2004-08-30 16:16) [5]

только что у себя тестировал, все работает


 
Sheriff   (2004-08-30 16:20) [6]

может это важно: разрабатываю базу в IBExpert 2004.08.11
вот там ошибка и проявляется.


 
Роман Снегирев   (2004-08-30 16:26) [7]

а я и тестировал у себя в IBExpert. Может у тебя база слегка похерилась, попробуй Backap\Restore


 
Sheriff   (2004-08-30 16:28) [8]

спасибо, буду еще повозиться...


 
guest_Dmitry   (2004-08-30 16:42) [9]

>parameter mismatch for procedure

такое исключение кажется поднимается когда не хватает (лишние) параметров для процедуры.


 
guest_Dmitry   (2004-08-30 16:51) [10]

либо, если
>да, процедура должна возвращать значение типа double precision.

попробуй: select <value> from calculatevalue(new.parentid) into :<variable>;


 
TohaNik ©   (2004-08-30 16:53) [11]

>да, процедура должна возвращать значение типа double precision.
Syntax EXECUTE PROCEDURE name [: param [, : param …]]
[RETURNING_VALUES : param [, : param …]];



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

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

Наверх




Память: 0.48 MB
Время: 0.05 c
14-1094359127
olookin
2004-09-05 08:38
2004.09.26
Процент сов, жаворонков и сусликов...


1-1095067054
kukuikar
2004-09-13 13:17
2004.09.26
Как перехватить клики в IE?


9-1085751026
MrAngel
2004-05-28 17:30
2004.09.26
Что лучше ID3DXMesh или использование IndexBuffer и VertexBuffer?


4-1092711543
FastByte
2004-08-17 06:59
2004.09.26
Переключение рус./лат.


14-1094213765
}|{yk
2004-09-03 16:16
2004.09.26
Не мог бы кто проконсультировать...