http://www.firebirdsql.org/en/writing-udfs-for-interbase/ 를 참조해보면 파라미터 값에 정수가 바로 오는 것이 아니라 포인터를 이용하고 있습니다. 고수분들이 다 어디가셨나? 답변이 왜 없데...
NeoDreamer 님이 쓰신 글 :
: 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 작성이나 등록을 하기위한 특별한 방법(필수 요건, 제약조건 등등)이 있나요?
:
:
|