UDF 작성을 테스트 해 보고 있는데 아주 간단하게 만들어서 동작을 테스트 하고 있습니다.
UDF 등록과 실행은 문제가 없는데 반환값이 이상입니다.
UDF 는 아래와 같이 간단하게 만들고
extern "C" __declspec(dllexport) int i_mul( int a, int b )
{
return (a * b);
}
extern "C" __declspec(dllexport) double pi()
{
return 3.141592;
}
Firebird 서버에 등록을 하였습니다.
DECLARE EXTERNAL FUNCTION i_mul
INTEGER, INTEGER
RETURNS INTEGER BY VALUE
ENTRY_POINT 'i_mul' MODULE_NAME 'MyUDF';
DECLARE EXTERNAL FUNCTION pi
RETURNS DOUBLE PRECISION BY VALUE
ENTRY_POINT 'pi' MODULE_NAME 'MyUDF';
그리고 실행을 해 보았는데.
select i_mul(10, 4) from rdb$database;
결과가 원하는 값이 나오지 않고 엉뚱 한 값(870368256)이 반환 됩니다.
매개변수가 없는 경우는 정상적인 반환값을 전달 하여 줍니다.
UDF를 위한 DLL 작성이나 등록을 하기위한 특별한 방법(필수 요건, 제약조건 등등)이 있나요?
|