orcale利用输出参数返回游标,实现返回数据集效果

如此定义一个类型(RETURN   return_type在下面的例子中应该省略)
CREATE   OR   REPLACE   PACKAGE   cv_types   AS
--       TYPE   GenericCurTyp   is   REF   CURSOR   RETURN   return_type;
      TYPE   GenericCurTyp   is   REF   CURSOR;
END   cv_types;
过程如此建立。
PROCEDURE   open_cv   (generic_cv   IN   OUT   cv_types.GenericCurTyp,   choice   NUMBER)   IS
BEGIN
      IF   choice   =   1   THEN
            OPEN   generic_cv   FOR   SELECT   *   FROM   emp;
      ELSIF   choice   =   2   THEN
            OPEN   generic_cv   FOR   SELECT   *   FROM   dept;
      ELSIF   choice   =   3   THEN
            OPEN   generic_cv   FOR   SELECT   *   FROM   salgrade;
      END   IF;
END;
注意:返回的游标必须是第一个参数,且要指明参数类型为ftCursor
相信对你会很有帮助。

不足:oracle现在不能返回动态SQL的查询结果。
但可以使用以下方法达到同样的效果
OPEN   generic_cv   FOR   'SELECT   *   FROM   emp   WHERE   empid   >   '||   Parameter   ;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值