oracle:批量插入不同方案对比

实时测试的速度:

--48466条数据

--1.297

inline view更新法

inline view更新法就是更新一个临时建立的视图

update (select a.join_stateas join_state_a,b.join_stateas join_state_b

from t_join_situation a, t_people_info b where a.people_number=b.people_number

and a.year='2011' and a.city_number='M00000' and a.town_number='M51000'

) set join_state_a=join_state_b

 括号里通过关联两表建立一个视图,set中设置好更新的字段。这个解决方法比写法较直观且执行速度快。但表B的主键一定要在where条件中,并且是以“=”来关联被更新表,否则报错误

--7.156

update  t_join_situation aset a.join_state=(select b.join_statefrom t_people_info b

where a.people_number=b.people_number

and a.year='2011' and a.city_number='M00000' and a.town_number='M51000')

where exists (select 1 from t_people_info b

where a.people_number=b.people_number

and a.year='2011' and a.city_number='M00000' and a.town_number='M51000')

 

--3.281

begin

for crin (select a.rowid,b.join_statefrom t_join_situation a,t_people_info b

where a.people_number=b.people_number

and a.year='2011' and a.city_number='M00000' and a.town_number='M51000')loop

update t_join_situationset join_state=cr.join_statewhere

rowid = cr.rowid;

end loop;

end;

 

--1.641

merge into t_join_situation a

using  t_people_info b

on (a.people_number=b.people_number

and  a.year='2011' and a.city_number='M00000' and a.town_number='M51000')

when matched then update set a.join_state=b.join_state

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值