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

Вниз

Использование 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;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.022 c
1-79002
Aik
2003-11-12 10:39
2003.11.24
Кнопка вперёд и назад, Twebbrowser


3-78790
Alibaba
2003-11-04 13:17
2003.11.24
Результат


7-79206
Незнайко
2003-09-13 15:00
2003.11.24
Время копирования


14-79177
undert
2003-10-30 19:17
2003.11.24
ПОМОГИТЕ ! TStringGrid


3-78857
Andrey000
2003-11-03 11:56
2003.11.24
Помогите с ADO не освобождается память