Oracle通过其实际存储过程中返回相关数据集

以下的文章主要介绍的是Oracle通过存储过程中返回相关数据集的实际操作方案,我们首先要了解的是如何正确的使用存储过程来返回数据集,我们大家都知道Oracle数据库中的存储过程返回数据集是Oracle通过ref cursor类型数据的参数返回的。

而返回数据的参数应该是out或in out类型的,由于在定义存储过程时无法直接指定参数的数据类型为:ref cursor,而是首先Oracle通过以下方法将ref cursor进行了重定义:

 
 
 
  1. create or replace package FuxjPackage is
  2. type FuxjResultSet is ref cursor;

还可以定义其他内容

 
 
 
  1. end FuxjPackage;

再定义存储过程:

 
 
 
  1. create or replace procedure UpdatefuxjExample (sDM in char,sMC in char, pRecCur in out FuxjPackage.FuxjResultSet)
  2. as
  3. begin
  4. update fuxjExample set mc=sMC where dm=sDM;
  5. if SQL%ROWCOUNT=0 then
  6. rollback;
  7. open pRecCur for
  8. select '0' res from dual;
  9. else
  10. commit;
  11. open pRecCur for
  12. select '1' res from dual;
  13. end if;
  14. end;

 
 
 
  1. create or replace procedure InsertfuxjExample 
    (sDM in char,sMC in char, pRecCur in out FuxjPackage.FuxjResultSet)
  2. as
  3. begin
  4. insert into FuxjExample (dm,mc) values (sDM,sMC);
  5. commit;
  6. open pRecCur for
  7. select * from FuxjExample;
  8. end;

在Delphi中调用返回数据集的存储过程

可以通过TstoredProc或TQuery控件来调用执行返回数据集的存储,数据集Oracle通过TstoredProc或TQuery控件的参数返回,注意参数的DataType类型为ftCursor,而参数的ParamType类型为ptInputOutput。

使用TstoredProc执行UpdatefuxjExample的相关设置为:

 
 
 
  1. object StoredProc1: TStoredProc
  2. DatabaseName = 'UseProc'
  3. StoredProcName = 'UPDATEFUXJEXAMPLE'
  4. ParamData = <
  5. item
  6. DataType = ftString
  7. Name = 'sDM'
  8. ParamType = ptInput
  9. end
  10. item
  11. DataType = ftString
  12. Name = 'sMC'
  13. ParamType = ptInput
  14. end
  15. item
  16. DataType = ftCursor
  17. Name = 'pRecCur'
  18. ParamType = ptInputOutput
  19. Value = Null
  20. end>
  21. end 

上述的相关内容就是对Oracle通过存储过程中返回数据集的描述,希望会给你带来一些帮助在此方面。

当前名称:Oracle通过其实际存储过程中返回相关数据集
分享路径:http://www.csdahua.cn/qtweb/news30/454330.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网