declare

--开始时间

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

--结束时间

v_date_end date:= to_date('2015-11-01 00:00:00','yyyy-mm-dd hh24: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',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;

/

总结

以上是编程之家为你收集整理的oracle 游标批量处理数据全部内容,希望文章能够帮你解决oracle 游标批量处理数据所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

oracle使用游标批量删除数据,oracle 游标批量处理数据相关推荐

  1. python mysql批量更新_Python批量删除mysql中千万级大量数据的脚本分享

    场景描述 线上mysql数据库里面有张表保存有每天的统计结果,每天有1千多万条,这是我们意想不到的,统计结果咋有这么多.运维找过来,磁盘占了200G,最后问了运营,可以只保留最近3天的,前面的数据,只 ...

  2. python处理千万级数据_Python批量删除mysql中千万级大量数据的脚本分享

    场景描述 线上Mysql数据库里面有张表保存有每天的统计结果,每天有1千多万条,这是我们意想不到的,统计结果咋有这么多.运维找过来,磁盘占了200G,最后问了运营,可以只保留最近3天的,前面的数据,只 ...

  3. think php批量删除代码,ThinkPHP实现批量删除数据的代码实例

    ThinkPHP实现批量删除数据的代码实例 ThinkPHP实现批量删除数据原理很简单,只需在模板页面里面写上这样传过来就是一个数组,action的删除函数del()如下: /** **删除函数支持删 ...

  4. ORACLE实例控制文件删除恢复,Oracle案例:损坏控制文件的恢复方法

    一: 损坏单个控制文件 损坏单个控制文件是比较容易恢复的,因为一般的数据库系统,控制文件都不是一个,而且所有的控制文件都互为镜相,只要拷贝一个好的控制文件替换坏的控制文件就可以了. 1.控制文件损坏, ...

  5. python查询千万级数据_Python批量删除mysql中千万级大量数据

    场景描述 线上mysql数据库里面有张表保存有每天的统计结果,每天有1千多万条,这是我们意想不到的,统计结果咋有这么多.运维找过来,磁盘占了200g,最后问了运营,可以只保留最近3天的,前面的数据,只 ...

  6. tp5批量删除ajax,tp5.1批量删除商品

    选中要删除的商品,点击批量删除 先在控制器使用sql语句查出商品信息goods 然后在html源码中使用goods变量. {foreach $goods as $item} 1232324 {/for ...

  7. win7怎么把计算机删除文件,win7电脑怎么批量删除文件_win7电脑批量删除文件的方法 - 系统家园...

    在我们日常使用win7系统电脑时,应该有很多用户遇到过需要批量删除文件的情况,那么win7电脑怎么批量删除文件呢?下面小编就为大家带来win7电脑批量删除文件的方法,感兴趣的小伙伴快来看看吧. win ...

  8. oracle唯一索引能删除吗,Oracle:ora-02429:无法用于删除强制唯一/主键的索引 解决...

    今天打算删除orcale数据库中无用的表空间,发现报错,查资料删除,写个过程留着备用. 1.drop tablespace dldata INCLUDING CONTENTS CASCADE CONS ...

  9. java 批量删除_java根据id批量删除

    1.mapper.xml 传入的参数可以是List也可以是Array数组,ParameterType都写List就可以collection="array"也可以写成collecti ...

  10. oracle如何删除一个用户下的所有数据?

    在oracle中,如何删除一个用户下的所有数据? 1.用sql*plus,或者在plsql.toad中使用sys身份登陆数据库 2.然后执行下面语句: DROP USER user_name (用户名 ...

最新文章

  1. Revisiting Salient Object Detection: Simultaneous Detection, Ranking, and Subitizing of Multiple Sal
  2. 图像缩放的双线性内插值算法的原理解析
  3. Mysql多表查询笔记
  4. mysql 分页效率_MYSql分页查询效率提高
  5. 设计一个分步式登录系统_分布式系统:何时构建它们以及如何扩展。 分步指南。
  6. 百度API获取位置范围内的周边服务
  7. 提升 JavaScript 技能的5个小技巧,新手小白值得学习!
  8. Linux哲学家进餐杀死进程,100分跪求“哲学家就餐问题”在 Linux下运行的源代码(后缀名为.c)!!!...
  9. 用Photoshop制作简单贺卡
  10. php+psr4和自动加载,php自动加载规范 PSR4 (Thinkphp)
  11. MySQL数据库INSERT、UPDATE、DELETE以及REPLACE语句的用法详解
  12. 爬取淘宝商品评论——2020-8月
  13. winhex使用简介
  14. 信号ctft频谱matlab,信号、系统分析与控制(MATLAB版)第4章连续信号的频域分析.ppt...
  15. diy计算机组装注意事项,DIY电脑组装教程:diy装机之三大原则八项注意
  16. paper论文搜集技巧(paperswithcode)
  17. 树模型(四):随机森林
  18. chrome-调试按钮详解
  19. 区块链技术在网络安全上的应用
  20. Javascript vue 数组中的对象分离 获取对象属性名称 对象属性值

热门文章

  1. PAT乙级(1031 查验身份证)
  2. Tensorflow——会话
  3. axure日期选择器组件_vue干货分享,超过六种组件通信方法讲解和精髓归纳
  4. 直播丨墨天轮邂逅MySQL之父,腾讯云CDB/CynosDB技术揭秘之自主可控、前沿探索
  5. 下载丨 MySQL运维管理+编程开发大全
  6. Oracle 20c 新特性:基础级内存数据库免费功能 In-Memory Base Level
  7. 披荆斩棘:饿了么业务架构的演进之路
  8. 华为云API Explorer开发者生态平台正式上线
  9. 搞清楚一道关于Integer的面试题
  10. 【带着canvas去流浪(13)】用Three.js制作简易的MARVEL片头动画(下)#华为云·寻找黑马程序员#