Oracle 存储过程学习笔记(四)

    Oracle使用存储过程返回结果集必须使用包,包包括包头和包体两部分,包头是定义部分包体是具体的实现

    包头:

    CREATE OR REPLACE

    PACKAGE pkg_test_select_mul

    AS

    TYPE myrctype IS REF CURSOR; 

    PROCEDURE proc(s number, res OUT myrctype);

END pkg_test_select_mul;

    这里定义了个一个游标和一个存储过程。

    包体:

    CREATE OR REPLACE

    PACKAGE BODY "PKG_TEST_SELECT_MUL" AS

        PROCEDURE proc(s in number,res OUT myrctype)

        IS       

        BEGIN       

          OPEN res FOR Select  emp_id,emp_Name, salary,birthday From            emp where salary> s;

        END proc;   

    END PKG_TEST_SELECT_MUL;

    这里实现里包头中定义的存储过程,实现了查询工资超过一定数额的人的信息,而游标则不用重新定义了,且存储过程中的参数名必须和定义中的一致。下面我们看一下C#的调用部分。

    OracleConnection conn = new OracleConnection();   //创建一个新连接

            conn.ConnectionString = "Data Source='" + "MyTest" + "';user id='" + "azkaser" + "';password='" + "sti" + "';";   //写连接串 

            OracleCommand cmd = new OracleCommand("PKG_TEST_SELECT_MUL.proc", conn);

            cmd.CommandType = CommandType.StoredProcedure;

            OracleParameter p1 = new OracleParameter("s", OracleType.Number);

            p1.Value = 4000;

            p1.Direction = ParameterDirection.Input;

            OracleParameter p2 = new OracleParameter("res", OracleType.Cursor);

            p2.Direction = ParameterDirection.Output;

 

            cmd.Parameters.Add(p1);

            cmd.Parameters.Add(p2);

            conn.Open();

            OracleDataReader myReader = cmd.ExecuteReader();

            while (myReader.Read())

            {

                MessageBox.Show(myReader.GetString(1));

            }

            conn.Close();

    程序将得到的结果存放在OracleDataReader的对象中。

    到此简单的Oracle存储过程操作就此就全部完成了,程序写的很随便,目的就是实现功能,将来有时间会进一步斟酌每个部分。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值