使用動態遊標的原因在於有時候傳進遊標的值可能是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; --打開動態遊標