C#调用oracle存储过程(返回数据集)

本文介绍如何在Oracle中创建一个简单的存储过程用于查询STUDENT表,并通过C#应用程序调用该存储过程获取数据。

表:STUDENT(NAME,SEX,SCORE)
ORACLE包和存储过程:首先在ORACLE建立PACKAGE和PACKAGE BODY,将在这里面定义函数和存储过程返回结果集。
 1,建立PACKAGE:
 CREATE OR REPLACE PACKAGE SENYI.PACK_STU
IS
 TYPE T_CURSOR IS REF CURSOR;
 PROCEDURE PRO_STUDENT(RE_CURSOR OUT T_CURSOR);
 END;
 /
 说明:其实PACKAGE只是个声明罢了。我们在这里定义了一个存储过程返回结集。
 2,建立PACKAGE BODY:
 CREATE  OR REPLACE PACKAGE BODY SENYI.PACK_STU
 IS
 PROCEDURE PRO_STUDENT(RE_CURSOR OUT T_CURSOR)
 IS
 V_CURSOR T_CURSOR;
 BEGIN
 OPEN V_CURSOR FOR
   SELECT * FROM SENYI.STUDENT;
   RE_CURSOR:=V_CURSOR;
   END;
  END;
  /
说明:这里建立PACKAGE BODY是具体的说明和使用,将采用什么方式实现。。
------------------------------
c# 部分:
        string str="server=ORCL;user id=senyi;password=orcl";
        OracleConnection con = new OracleConnection(str);
        con.Open();
        OracleParameter[] para = new OracleParameter[]{
            new OracleParameter("RE_CURSOR", OracleType.Cursor)             
        };
        para[0].Direction = System.Data.ParameterDirection.Output;
        OracleCommand cmd = new OracleCommand();
        cmd.Connection = con;
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.CommandText = "SENYI.PACK_STU.PRO_STUDENT";//注意此处存储过程的调用: 包+存储过程名
        foreach (OracleParameter pa in para)
        {
            cmd.Parameters.Add(pa);
        }
       
        OracleDataAdapter da = new OracleDataAdapter();
        da.SelectCommand = cmd;
        DataSet ds = new DataSet();
        da.Fill(ds);
        con.Close();
        DataTable dt = ds.Tables[0];
        this.GridView1.DataSource = dt;
        this.GridView1.DataBind();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值