1.要把C写成扩展的形式 ex.c文件
int __declspec(dllexport) sum(int a,int b) { return a+b; }
2.把C代码编译成动态库(*.dll 或 *.so)
C:\>gcc -O -shared -o ex.dll ex.c
3.把 ex.dll 拷贝到数据库的bin目录 D:\app\11.1.0\db_1\BIN\
D:\app\11.1.0\db_1为我的Oracle 安装目录
4.连接动态库,用SYS帐号登录系统(此处为演示,所以直接用SYS登录,其他普通帐号可能权限有问题)
create or replace library MYLIB as ‘D:\app\11.1.0\db_1\BIN\ex.dll‘; create or replace function my_sum(l_a in binary_integer,l_b in binary_integer) return binary_integer as language C name "sum" library MYLIB parameters(l_a,l_b);
5.使用
select my_sum(120,2) from dual
执行结果如下
MY_SUM(120,2)
----------------------
122
1 rows selected
时间: 2024-11-05 16:34:52