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; --打開動態遊標

發佈了4 篇原創文章 · 獲贊 3 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章