FireBird Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
파이어버드 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
IBPhoenix
FireBird Main site
볼랜드포럼 광고 모집

FireBird FAQ
[6] UDF는 무엇입니까?
박지훈.임프 [cbuilder] 14474 읽음    2005-10-05 02:24
UDF는 User Defined Function의 약자로서, 번역하자면 사용자 정의 함수입니다. UDF는 파이어버드나 인터베이스 외부의 바이너리 형태인데, 윈도우의 경우 DLL, 유닉스에서는 so의 형태로 함수들을 만들어서 SQL문에서 호출할 수 있게 하는 것입니다.

인터베이스/파이어버드에서는 기본 내장 함수는 여섯개 뿐입니다. 그렇다고 해서 이 여섯개의 함수로 모든 것을 알아서 하라는 뜻은 아니고, 나머지는 모두 UDF의 형태로 제공됩니다.

인터베이스와 파이어버드에는 기본으로 내장된 UDF들이 있습니다. 다음은 인터베이스와 파이어버드 두가지 모두에 내장된 UDF 라이브러리인 UDF 함수들입니다. 이 외에 파이어버드에는 fbudf.dll이 추가로 포함되어 있습니다.

산술 함수
div : 나눗셈의 몫
mod : 나눗셈의 나머지
abs : 절대값
ceiling : 인자보다 크거나 같은 최대의 정수
floor : 인자보다 작거나 같은 최대의 정수
rand : 0~1 사이의 임의 값
sign : 인자가 양수이면 1, 음수이면 -1, 0이면 0을 리턴

문자열 함수
ascii_char : 정수 인자값을 아스키 문자(char)로 리턴
ascii_val : 문자(char) 인자를 아스키 정수값으로 리턴
lower : 소문자로 변환 (upper는 기본 내장 함수)
ltrim : 문자열 앞의 공백 지움
rtrim : 문자열 뒤의 공백 지움
lpad : 문자열의 앞에 지정한 문자를 지정한 갯수만큼 추가해서 리턴
rpad : 문자열의 뒤에 지정한 문자를 지정한 갯수만큼 추가해서 리턴
substr : 문자열에서 지정한 위치부터 지정한 위치까지의 일부 문자열
substrlen : 문자열에서 지정한 위치부터 지정한 갯수만큼의 일부 문자열
strlen : 문자열의 길이

바이너리 연산
bin_and, bin_or, bin_xor

삼각함수, 로그 등 수학 함수
sin, cos, tan, cot
asin, acos, atan, atan2
sinh, cosh, tanh
log, log10, ln
sqrt, pi

윈도우에서 UDF는 DLL에 포함된 형태이기 때문에 델파이나 C++빌더, 심지어는 비주얼 C++에서도 만들 수 있습니다. UDF를 사용하려면 먼저 사용하려는 데이터베이스에 등록하는 선언적인 SQL문이 필요한데, 이것은 델파이나 C++에서 다른 모듈의 함수를 사용하기 전에 함수 프로토타입(선언)이 필요한 것과 같다고 이해하면 됩니다.

UDF를 등록하는 SQL 문법은 DECLARE EXTERNAL FUNCTION 문입니다. 예를 들어 ib_udf.dll에 포함된 div 함수를 선언하려면 다음과 같이 하면 됩니다.
DECLARE EXTERNAL FUNCTION div 
	INTEGER, INTEGER
	RETURNS DOUBLE PRECISION BY VALUE
	ENTRY_POINT 'IB_UDF_div' MODULE_NAME 'ib_udf';

이런 UDF 선언 SQL 문의 구성을 생각할 필요없이, 보통 UDF 라이브러리(DLL)을 배포할 때 선언 SQL문을 같이 배포하는 것이 보통이므로 해당 UDF 함수의 선언 SQL문을 찾아서 그대로 복사해서 실행해주면 해당 함수를 데이터베이스에서 사용할 수 있게 됩니다.

+ -

관련 글 리스트
6 UDF는 무엇입니까? 박지훈.임프 14474 2005-10-05
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.