[UDF系列]如何编写InterBase UDF 之三

(接上一篇)

如何编写InterBase UDF

warton

(前面讲了在windows下编写UDF)

编写Linux/Unix平台的UDF

(译者注:原用大量篇幅讲述了linux下的SO(shared object)文件和windows下的DLL文件,其实它们都是一种动态链接库,在此不做详细翻译!)

 

怎么在Linux 下生成一个shared library(共享库)

1.建立一个C文件(扩展名为.c

2.建立模块函数:int modulo(int *, int *);

  
  
   
    
  
  
int modulo(a, b)
     int *a;
     int *b;
{
  if (*b == 0)
    return -1; // return something suitably stupid.
  else
    return *a % *b;
}

  
  
   
    
  
  
编译和使用它
     
     

   
   
    
     
   
   
在命令行下:
    
    
gcc -c -O -fpic -fwritable-strings <your udf>.c
ld -G <your udf>.o -lm -lc -o <your udflib>.so
cp <your udflib>.so /usr/interbase/udf
然后在ISQL中:
declare external function f_Modulo
integer, integer
returns
integer by value
entry_point 'modulo' module_name 'name of shared library';

  
  
   
    
  
  
commit;

  
  
   
    
  
  
select f_Modulo(3, 2) from rdb$database;

  
  
   
    
  
  
真是太简单了!!

  
  
   
    
  
  
结论:
        看来编写UDF真的不难!看,它包含的内容也不太多!毕竟Linux开发者也不为难了。
最后:
    
    
        如果你想要更好的编程例子,可以下载FreeUDFLib—一个Delphi的UDF库和一个FreeUDFLibC―一个基于C的UDF库,它可以运行在Solaris,Linux,Windows等

  
  
   
    
  
  
(注,由于原本少量内容与主题无关,本人没有翻译)
     
     
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值