中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

oracle 游標批量處理數據

發布時間:2020-07-27 10:46:12 來源:網絡 閱讀:852 作者:lxg290 欄目:關系型數據庫

declare

  --開始時間

  v_date_start date:= to_date('2015-05-28 00:00:00', 'yyyy-mm-dd hh34:mi:ss');

  --結束時間

  v_date_end   date:= to_date('2015-11-01 00:00:00', 'yyyy-mm-dd hh34:mi:ss');

  --臨時變量

  v_date_plus date;

  type type_policy_no is table of ply_base_info.policy_no%type;

  v_policy_no type_policy_no;

  

  type type_compensation_max_amount is table of ply_duty.compensation_max_amount%type;

  v_compensation_max_amount type_compensation_max_amount;

  

  type type_id_ply_duty is table of ply_duty.id_ply_duty%type;

  v_id_ply_duty type_id_ply_duty;

  

  type type_insurance_end_date is table of ply_base_info.insurance_end_date%type;

  v_insurance_end_date type_insurance_end_date;

  

  cursor plyNumberCur is  

   select 

           pbi.policy_no, 

           pd.compensation_max_amount,

           pd.cover_spouse,

           pdn.noclaim_rate,

           pdn.noclaim_amount,

           pd.id_ply_duty,

           trunc(pbi.insurance_end_date)

      from ply_base_info    pbi,

           marketproduct_info mi,

           ply_risk_group   prg,

           ply_plan         pp,

           ply_duty         pd,

           ply_duty_noclaim pdn

     where   pbi.created_date >=v_date_start

         and pbi.created_date < v_date_plus

         and pbi.policy_no is not null

         and pbi.product_code= mi.marketproduct_code

         and pbi.product_version=mi.version

         and mi.product_class in ('02','03')

         and pbi.id_ply_base_info = prg.id_ply_base_info

         and prg.id_ply_risk_group = pp.id_ply_risk_group

         and pp.id_ply_plan = pd.id_ply_plan                    

         and pd.id_ply_duty = pdn.id_ply_duty(+); 

    v_cnt number;--用來統計是否有數據

begin

 loop 

   v_date_plus:=v_date_start+1;--時間變化,查詢游標時,每天查詢一次

     open plyNumberCur;--打開游標

  loop

   --每1000條記錄取一次,最后一次不夠1000的也將取出,放到變量中

   fetch plyNumberCur bulk collect into  

    v_policy_no,v_compensation_max_amount,v_id_ply_duty,v_insurance_end_date limit 1000 ;

    for i in 1..v_policy_no.count loop

    if  v_compensation_max_amount(i) > 0 then

      select count (pda.id_ply_duty) into v_cnt  from  ply_duty_attribute pda where pda.id_ply_duty = v_id_ply_duty(i) and pda.duty_attr_code='6';

      if v_cnt>0 then

         update  ply_duty_attribute pda set pda.duty_attr_amount_value=to_char(v_compensation_max_amount(i)), pda.UPDATED_BY='lxg' where pda.id_ply_duty = v_id_ply_duty(i) and pda.duty_attr_code='6' and pda.UPDATED_BY<>'lxg';

      else

        insert into ply_duty_attribute(ID_PLY_DUTY_ATTRIBUTE,ID_PLY_DUTY,DUTY_ATTR_CODE,DUTY_ATTR_AMOUNT_VALUE ,POLICY_NO,  CREATED_DATE,CREATED_BY,UPDATED_DATE,UPDATED_BY,ARCHIVE_DATE)

         values(sys_guid(),v_id_ply_duty(i),'6',to_char(v_compensation_max_amount(i)),v_policy_no(i),sysdate,'lxg',sysdate,'lxg',v_insurance_end_date(i));

      end if;

    end if;   

   end loop;--for end;

   commit;

  --當游標中沒有數據將退出

  exit when plyNumberCur%notfound;

 end loop; --for end;

    close plyNumberCur;

  v_date_start:= v_date_start+1;

  if v_date_start>= v_date_end then

     exit;

  end if;

 end loop; --loop

end;

/


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

聊城市| 六安市| 溆浦县| 陕西省| 成都市| 格尔木市| 太白县| 信宜市| 岳阳县| 长兴县| 织金县| 洞口县| 祁东县| 富平县| 霍山县| 罗田县| 承德县| 黑龙江省| 师宗县| 布尔津县| 洞头县| 青州市| 龙州县| 噶尔县| 乌鲁木齐县| 监利县| 万载县| 松溪县| 福建省| 慈溪市| 屏边| 南木林县| 荔波县| 东光县| 景泰县| 静宁县| 泗水县| 甘肃省| 威信县| 开鲁县| 乳山市|