ORACLE 两表更新 update

oralce 的两个表关联更新 写法和另类 与MS SQL很不一样

有时候更新大表速度特慢 5-10个小时都没结束

 

UPDATE T_BASE_SUCC_PROUSER X SET X.F_EXPECTENDDATE = ( SELECT E.F_ENDTIME FROM T_GATHER_EXPECT E WHERE X.F_LOTID=E.F_LOTTERYID AND X.F_EXPECT=E.F_EXPECT )
T_BASE_SUCC_PROUSER 昨天更新了14个小时都没解释
今天加个索引也跑那么慢
首次加载时间  2009-9-8 10:38:5 到现在15:58分近五个小时了
而且EM上看IO量维持很低
表大小7205M 行7758,5575
执行计划
操作                对象            对象类型 顺序    行    大小 (KB)    成本  时间 (秒) CPU 成本    I/O 成本
TABLE ACCESS FULL T_BASE_SUCC_PROUSER TABLE 1    77585575 1,439,576.099 169053  2029      36788100922  164759
TABLE ACCESS FULL T_GATHER_EXPECT    TABLE 2    1          0.021        139        2        25736801    136


想这样更新大表 而且IO利用率那么低 各位如何写这样更新语句啊

 

 

1

UPDATE T_BASE_SUCC_PROUSER X SET X.F_EXPECTENDDATE = ( SELECT E.F_ENDTIME FROM T_GATHER_EXPECT E WHERE X.F_LOTID=E.F_LOTTERYID AND X.F_EXPECT=E.F_EXPECT )
where exists(select 1 from T_GATHER_EXPECT E WHERE X.F_LOTID=E.F_LOTTERYID AND X.F_EXPECT=E.F_EXPECT)

 

后面一定要加上where exists(select 1 from T_GATHER_EXPECT E WHERE X.F_LOTID=E.F_LOTTERYID AND X.F_EXPECT=E.F_EXPECT) ,不能的话所以的数据行都将修改,当然每行只是修改一次。

 

2

 建议用Update视图的方式来做。
update (select x.F_EXPECTENDDATE,E.F_ENDTIME
          from T_BASE_SUCC_PROUSER X left join T_GATHER_EXPECT E on X.F_LOTID=E.F_LOTTERYID AND X.F_EXPECT=E.F_EXPECT
)
set F_EXPECTENDDATE=F_ENDTIME

 

两表需要外键关链

 

3 临时表法

create table a as

select  x.*,e.f_endtime

from x

inner join  e  on  x.f_lotid=e.f_lotid and e.id=x.id

 

truncate table  x

insert into x select * from a;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值