Форум: "Базы";
Текущий архив: 2003.11.24;
Скачать: [xml.tar.bz2];
ВнизИспользование UDF в SQL запросах Interbase Найти похожие ветки
← →
Pul (2003-11-04 15:48) [0]При попытке выплнения запроса, в котором трижды вызывается UDF функция вылетает ошибка:
Invalid token.
invalid request BLR at offset 254.
Implementation limit exceeded.
block size exceeds implementation restriction.
А если оставить два вызова этой же функции, то все работает нормально.
Предупреждаю сразу, функция работает правильно, в базе задкларирована.
Текст запроса
select * from "CodeList" where
"CodeList"."GrID"=:CLGRID and
anklike("CodeList"."AValue1", :PAR1, 8)=1 and
anklike("CodeList"."AValue3", :PAR3, 8)=1 and
anklike("CodeList"."AValue4", :PAR4, 8)=1
Может кто-то сталкивался с этой проблемой.
← →
Johnmen (2003-11-04 16:02) [1]Самописная функция ?
И как задекларирована ?
← →
Pul (2003-11-04 16:10) [2]>Johnmen
DECLARE EXTERNAL FUNCTION ANKLIKE
BLOB,
VARCHAR (32000),
INTEGER
RETURNS INTEGER BY VALUE
ENTRY_POINT "ANKLIKE" MODULE_NAME "ankudf.dll";
← →
Fay (2003-11-04 16:12) [3]Покажи код
← →
Pul (2003-11-04 16:14) [4]Уже вроде бы понял, только как исправить не знаю.
При изменении в декларации функции VARCHAR (32000) на VARCHAR (100) запрос работает. Но это не решение проблемы. Мне просто необходимо передавать такие строки.
← →
Pul (2003-11-04 16:15) [5]> Fay
какой именно код?
← →
Fay (2003-11-04 16:17) [6]UDF
← →
Johnmen (2003-11-04 16:19) [7]CSTRING(32000)
← →
Pul (2003-11-04 16:31) [8]> Fay
С кодом UDF все в порядке, он работает на 100%
Рассматривать его не имеет смысла. Могу привести заголовок:
function ANKLIKE(B: PBlob; SStr: PChar; Porog: PLongint): Integer; cdecl; export;
>Johnmen
При подобной замене необходимо наверное изменить исходник процедуры и перекомпилить UDF dll. А как CSTRING (32000) передается в Delphi?
← →
mOOx_ (2003-11-04 16:37) [9]Вообще, РТФМ по этому поводу на ибазе.ру. А вкратце, cstrings - это что-то типа ПЧар (если не ошибаюсь :) ).
Удачи.
Страницы: 1 вся ветка
Форум: "Базы";
Текущий архив: 2003.11.24;
Скачать: [xml.tar.bz2];
Память: 0.46 MB
Время: 0.009 c