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

Вниз

Функция Trim в InterBase   Найти похожие ветки 

 
RomanH ©   (2006-06-16 11:15) [0]

Здраствуйте мастера.Не могу найти функцию trim в IB, может существует подобная функция.


 
_dimka ©   (2006-06-16 11:30) [1]

она в ib_udf, ее нужно задекларировать, точка входа IB_UDF_ltrim


 
RomanH ©   (2006-06-16 11:50) [2]


> _dimka ©

Как вы сказали я задекларировал
DECLARE EXTERNAL FUNCTION TRIM
   CHAR(10)
RETURNS VARCHAR(10) FREE_IT
ENTRY_POINT "IB_UDF_ltrim" MODULE_NAME "ib_udf.dll"

Затем в SQL-Editore
делаю запрос
select trim (doc_types.doc_extension) from doc_types
where doc_types.doc_type_id=2

Но при запуске запроса IBEXPERT пишет ошибку

Invalid token.
invalid request BLR at offset 76.
function TRIM is not defined.
module name or entrypoint could not be found.

Подскажите где моя ошибка


 
Johnmen ©   (2006-06-16 11:54) [3]

У тебя неверная декларация параметров. Параметры в UDF передаются по ссылке.
Читать http://www.ibase.ru/devinfo/udf_ok.htm


 
novill ©   (2006-06-16 12:33) [4]

Посмотрите, как записано объявление в мануале и сравните со своим.
(80 для примера взято)

DECLARE EXTERNAL FUNCTION LTRIM CSTRING(80)
RETURNS CSTRING(80) FREE_IT ENTRY_POINT "IB_UDF_ltrim" MODULE_NAME "ib_udf;

И удаляет она только лидирующие пробелы. Не путайте себя,  объявите Ltrim и Rtrim.


 
RomanH ©   (2006-06-16 13:05) [5]

DECLARE EXTERNAL FUNCTION RTRIM
CSTRING(80) CHARACTER SET WIN1251
RETURNS CSTRING(80) CHARACTER SET WIN1251 FREE_IT
ENTRY_POINT "IB_UDF_rtrim" MODULE_NAME "ib_udf";

Запуская хранимую процедуру
REATE PROCEDURE TRIM_EXTENSION (
   EXT INTEGER)
RETURNS (
   EXTENSION SMALLINT)
AS
begin
     select rtrim(doc_types.doc_extension)  from doc_types
     where doc_types.doc_type_id=:ext into :extension;

end^

Получаю ошибку
Arithmetic overflow or division by zero has occurred.
arithmetic exception, numeric overflow, or string truncation.

Подскажите пожалуйста что делать


 
Desdechado ©   (2006-06-16 13:45) [6]

EXTENSION SMALLINT
а ты туда строку пхаешь, причем явно не преобразуемую в короткое целое

и вообще советую делать явные CAST, а не надеяться на неявный - ошибок будет на порядок меньше



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

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

Наверх




Память: 0.48 MB
Время: 0.047 c
4-1146219048
Creative
2006-04-28 14:10
2006.08.20
как избавиться от мерцания?


15-1153989001
Alert2006
2006-07-27 12:30
2006.08.20
Координаты


4-1145936912
Бабайка
2006-04-25 07:48
2006.08.20
Защита программы: как запустить приложение из памяти?


2-1154511794
Gnoll
2006-08-02 13:43
2006.08.20
FindFirst, FindNext .....


2-1154501900
Arsenija
2006-08-02 10:58
2006.08.20
обработка по нажатии ENTER в LabeledEdit