Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2006.08.20;
Скачать: [xml.tar.bz2];

Вниз

Функция 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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.042 c
2-1154428209
DelphiLexx
2006-08-01 14:30
2006.08.20
external без описания имени модуля


2-1154421420
RomanH
2006-08-01 12:37
2006.08.20
SQL-запрос


4-1145516275
Dimich1978
2006-04-20 10:57
2006.08.20
Программно нажать на кнопку закрытия формы(крестик)


2-1154588840
Neket
2006-08-03 11:07
2006.08.20
UDP


2-1154100660
qwe777
2006-07-28 19:31
2006.08.20
Добавление записей DBGrid





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский