oracle 动态游标

oracle 动态游标

      使用动态游标的原因在于有时候传进游标的值可能是in里面的多个值,而游标变量(如varchar类型)将这些值当做一个值来处理,这样就获取不到所需要的游标数据,这时候就需要动态游标

1.动态游标也属于游标的范畴,在变量定义的时候首先定义游标类型:

  TYPE My_CurType IS REF CURSOR;
  CUR_1  My_CurType; --指示CUR_1的类型为My_CurType,而My_CurType是游标类型

2.在需要使用的时候拼接sql执行游标:

strSql1 := '
 select lotinv.fdepotid,lotinv.fgoodsid,sum(lotinv.finprice*lotinv.fbaseqty)/sum(lotinv.fbaseqty),
       sum(lotinv.finprice*lotinv.fbaseqty)/(sum(lotinv.fbaseqty)*(1+lotinv.fintaxrate))
  from t_Rt_lotinventory lotinv
  where lotinv.fid in(' || v_forupdatre_lotids || ')  --
        group by
        lotinv.fintaxrate,
        lotinv.fdepotid,
        lotinv.fgoodsid      ';
3.打开动态游标,动态游标的使用和一般游标是一样的
  OPEN CUR_1 FOR strSql1; --打开动态游标

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值