C#来调用Oracle存储过程实操

本文主要讲述的是用C#来调用Oracle存储过程,还有返回,相关结果集,以及函数,首先我们主要简述如何在Oracle中建立PACKAGE与PACKAGE BODY,将在这里面定义函数和存储过程返回结果集。

目前成都创新互联公司已为上千的企业提供了网站建设、域名、网站空间绵阳服务器托管、企业网站设计、甘孜州网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

1:建立PACKAGE:

 
 
 
  1. CREATE OR REPLACE package SCOTT.pk_wt  
  2. is  
  3. type mytype is ref cursor;  
  4. procedure p_wt(mycs out mytype);  
  5. function f_get(str in varchar2)  
  6. return varchar2;  
  7. end;   

说明:其实PACKAGE只是个声明罢了。我们在这里定义了一个Oracle存储过程返回结集和一个函数,返回字符串。

2:建立PACKAGE BODY:

 
 
 
  1. CREATE OR REPLACE package BODY SCOTT.pk_wt  
  2. is  
  3. procedure p_wt(mycs out mytype)  
  4. is  
  5. begin  
  6. open mycs for select * from test;  
  7. end p_wt;  
  8. function f_get(str varchar2)  
  9. return varchar2  
  10. is  
  11. str_temp varchar2(100) := 'good luck!';   
  12. begin  
  13. str_temp := str_temp || str;  
  14. return str_temp;  
  15. end f_get;  
  16. end pk_wt;  
  17. /  

说明:这里建立PACKAGE BODY是具体的说明和使用,将采用什么方式实现。

C#段:

在C#中代码将分为两部分,一部分是使用函数,另外一部分是使用结果集。

定义一个连接,从WEBCONFIG里去取得:

 
 
 
  1. private OracleConnection orcn=new 
    OracleConnection(System.Configuration.
    ConfigurationSettings.AppSettings["scott"]); 

C#调用Oracle函数:

 
 
 
  1. OracleCommand cmd=new OracleCommand("pk_wt.f_get",orcn);  
  2. cmd.CommandType=CommandType.StoredProcedure;  
  3. OracleParameter p1=new OracleParameter("str",OracleType.VarChar,10);  
  4. p1.Direction=System.Data.ParameterDirection.Input;  
  5. p1.Value=this.TextBox1.Text;  
  6. OracleParameter p2=new OracleParameter("result",OracleType.VarChar,100);  
  7. p2.Direction=System.Data.ParameterDirection.ReturnValue;  
  8. cmd.Parameters.Add(p1);  
  9. cmd.Parameters.Add(p2);  
  10. orcn.Open();  
  11. cmd.ExecuteNonQuery();  
  12. orcn.Close();  
  13. this.Button_function.Text=p2.Value.ToString(); 

其中RESULT是系统自定义的函数返回变量,特别要注意的是,函数的参数的返回类型要指定,另外就是COMMAND类型也需要指定,另外和一般的Oracle存储过程没什么差别。

C#调用Oracle返回结果集:
 

 
 
 
  1. OracleCommand cmd=new OracleCommand("pk_wt.p_wt",orcn);  
  2. cmd.CommandType=CommandType.StoredProcedure;  
  3. OracleParameter p1=new OracleParameter("mycs",OracleType.Cursor);  
  4. p1.Direction=System.Data.ParameterDirection.Output;  
  5. cmd.Parameters.Add(p1);  
  6. OracleDataAdapter da=new OracleDataAdapter(cmd);  
  7. DataSet ds=new DataSet();  
  8. da.Fill(ds,"test");  
  9. this.DataGrid1.DataSource=ds;  
  10. this.DataGrid1.DataBind(); 

上述的相关内容就是对C#调用Oracle存储过程的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. Oracle字段的转字符串实际操作方案
  2. Oracle SQL的优化规则解析
  3. 闲谈Oracle应用数据库系统设计与开发简介
  4. Oracle SQL的优化的规则描述
  5. Oracle存储过程的编写经验总结

网站栏目:C#来调用Oracle存储过程实操
URL链接:http://www.mswzjz.cn/qtweb/news4/404554.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

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