c# oracle 返回数据集,C#显示存储过程返回的游标数据集

1、--Oracle 创建包 申明自定义游标类型

create or replace package pk_Var is

type csr_tp is ref cursor;

end;

2、--Oracle 创建存储过程返回数据集合

CREATE OR REPLACE PROCEDURE pr_getdata(

v_empno VARCHAR2 ,  RC1 out PK_Var.csr_tp  )

AS

sSQL  varchar2(2000) ;

begin

sSQL :=  ' select * from emp where empno=v_empno'  ;

Open RC1 for sSQL;

return;

end  pr_getdata;

3、c#代码如下:

//创建oracle参数

OracleParameter[] sqlParme = new OracleParameter[2]

//参数1

sqlParme[0] = new OracleParameter("RC1", OracleType.Cursor);

sqlParme[0].Direction = ParameterDirection.Output;

sqlParme[1] = new OracleParameter("TKALA", OracleType.VarChar);

sqlParme[1].Direction = ParameterDirection.Input;

sqlParme[1].Value = aHoleOldNum;

//从存储过程中获取dataTable数据源

private DataTable DBExecStoredProcedure(string storeureName, OracleParameter[] sqlParme)

{

try

{

//使用微软的ORACLE访问接口

if (DBHelper.G_pDBConn.State == ConnectionState.Closed)//获取数据连接

DBHelper.G_pDBConn.Open();

OracleCommand oraCmd = new OracleCommand(storeureName, DBHelper.G_pDBConn);

oraCmd.CommandType = CommandType.StoredProcedure;

oraCmd.Parameters.Clear();//先清空

foreach (OracleParameter parme in sqlParme)

{

oraCmd.Parameters.Add(parme);

}

DataTable table = new DataTable();

DateTime BegTime = System.DateTime.Now;

OracleDataAdapter da1 = new OracleDataAdapter(oraCmd);//取出数据

da1.Fill(table);

return table;

}

catch (Exception ex)

{

MessageBox.Show("执行存储过程失败:"+ex.Message,"调试");

return null;

}

finally {

DBHelper.G_pDBConn.Close();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值