Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103791491
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-04-15 13:05:36

     来源:赛迪网技术社区    作者:lemon

3.生成一个模仿外部函数的原型的PL/SQL子程序。

这个子程序就是用户可见的外部函数的PL/SQL接口,用户按照它的参数类型和返回值类型来使用外部函数,具体步骤为:

(1)在包体的声明部分,定义一个PL/SQL子程序,它的参数和返回值是和外部函数对应的PL/SQL类型。这就是模仿外部函数原型的一个子程序。

(2)在这个子程序中调用与上步生成的与外部函数相关联的PL/SQL子程序。

(3)在PL/SQL包的说明(PackageSpefication)部分,输入这个PL/SQL子程序的原型。

下面是一个完整的为WindowsAPI函数winexec建立PL/SQL接口的例子:

  
  PACKAGEWinExecIS
  FUNCTIONWinExec(ExecfileINVARCHAR2,
  commandINPLS_INTEGER)
  RETURNPLS_INTEGER;
  END;/*在包说明部分,是模仿外部
  函数原型的PL/SQL函数原型说明*/
  PACKAGEBODYWinExecIS
  lh_USERora_ffi.libHandleType;/*定义库柄类型变量*/
  fh_WinExecora_ffi.funcHandleType;/*定义函数柄类型变量*/
  
  FUNCTIONi_WinExec(funcHandleINora_ffi.funcHandleType,
  ExecfileINOUTVARCHAR2,
  commandINPLS_INTEGER)
  RETURNPLS_INTEGER;
  
  PRAGMAINTERFACE(C,i_WinExec,11265);
  /*步骤2将一个PL/SQL子程序与外部函数相关联*/
  
  FUNCTIONWinExec(ExecfileINVARCHAR2,
  commandINPLS_INTEGER)
  RETURNPLS_INTEGER
  IS
  execfile_lVARCHAR2(512):=Execfile;
  rcPLS_INTEGER;
  BEGIN
  rc:=i_WinExec(fh_WinExec,
  execfile_l,
  command);
  
  RETURN(rc);
  END;
  /*步骤3中PL/SQL模仿函数的定义,
  它实际上就是调用步骤2中与外部函数建立关联的那个函数*/
  BEGIN
  BEGIN
  lh_USER:=ora_ffi.find_library('Kernel32.dll');
  EXCEPTIONWHENora_ffi.FFI_ERRORTHEN
  lh_USER:=ora_ffi.load_library(NULL,'kernel32.dll');
  END;/*得到动态链接库的库柄*/
  
  fh_WinExec:=ora_ffi.register_function
  (lh_USER,'WinExec',ora_ffi.PASCAL_STD);
  /*得到外部函数的函数柄*/
  ora_ffi.register_parameter(fh_WinExec,
  ORA_FFI.C_CHAR_PTR);/*参数注册,原类型为LPCSTR*/
  ora_ffi.register_parameter(fh_WinExec,
  ORA_FFI.C_INT);/*参数注册,原类型为UINT*/
  
  ora_ffi.register_return(fh_WinExec,
  ORA_FFI.C_INT);/*返回值注册,原类型为BOOL*/
  
  ENDWinExec;
  

可以将多个外部函数的PL/SQL接口放在一个包内。要在Developer/2000的FormDesigner中使用这些外部函数,只要把包含这一程序包的程序库(.PLL)附加进来,使用包名.函数名就可激活这个外部函数。

例如:WinExec.WinExec('c:\windows\notepad.exe',0)

具体WindowsAPI函数数据类型和PL/SQL数据类型的转换可参照Developer/2000中ProcedureBuilder帮助文件中对ORA_FFI软件包的详细介绍。

阅读(242) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~