oracle 批量更新之将一个表的数据批量更新至另一个表

 

oracle 批量更新之将一个表的数据批量更新至另一个表

CreationTime--2018年7月3日17点38分

Author:Marydon

1.情景描述

  testdata表数据展示

  testdata2表数据展示

  数据对比:

  testdata表有31条数据,且有9条数据的userid与testdata2表不一致(自己独有);

  testdata2表有24条数据,且有2条数据的userid与testdata2表不一致(自己独有)。

  表关联:testdata表和testdata2表的userid具有关联关系

  需求说明:

  需要将testdata中的22条数据更新到testdata2表中   

2.错误方式

  这种方式,由于没有设置更新的限制条件,导致:

  不仅会更新需要更新的表记录,还会将testdata2中剩余的数据字段更新为空。

  

3.解决方案

  添加where条件,只对两表共有的数据进行更新。

  2018/12/05

  正确格式:

UPDATE TABLE1 T1
   SET (T1.COLUMN1, T1.COLUMN2) =
       (SELECT T2.COLUMN1, T2.COLUMN2 FROM TABLE2 T2 WHERE T2.ID = T1.ID) --两表能够进行关联的字段(一般是主键)
 WHERE EXISTS (SELECT 1 FROM TABLE2 T2 WHERE T2.ID = T1.ID);

  错误格式:

UPDATE TABLE1 T1
   SET (T1.COLUMN1, T1.COLUMN2) =
       (SELECT T2.COLUMN1, T2.COLUMN2 FROM TABLE2 T2 WHERE T2.ID = T1.ID)
 WHERE EXISTS (SELECT 1 FROM TABLE1 T1 WHERE T1.ID = T2.ID);--exists()访问不到t2表

  说明:虽然理论上,它们执行效果是一样的,但是由于exists()函数访问不到t2表,所以查询访问不到的那张表t2。

  套用

--添加限制条件,进行更新
update testdata2 t2
   set (t2.usercode, t2.userpassword) =
       (select t.usercode, t.userpassword
          from testdata t
         where t.userid = t2.userid)
 where exists (select 1 from testdata t where t.userid = t2.userid);

  避免了全表更新。 

  2018/12/07

4.索引的重要性

  更新1w条以上的数据时,where后面跟的条件一定要加上索引,不然哭都来不及。

  需要更新22w条数据,两张表的ID_CARD字段没有建索引

   两张表的ID_CARD字段建立索引后

  这是我的亲身经历,没有建索引前,执行了4个小时,没有更新完,后来由于电脑关机,导致任务终止;

  建索引后,同样执行该sql,更新22w条数据只用了4秒!!!  

说明:对于要执行的更新sql,使用plsql的预测功能时预测不准确,只做参考。

5.小结

  A表中有几个字段的值需要批量更新,如果一个一个进行修改,太慢了:

  将批量修改后的内容放到一个新的表中B,并与要更新的表A建立关联关系。

  第一步:建新表

  两表关联字段(column1):A表中该字段必须具有唯一性;

  要更新的字段(column5,cloumn6,...)。

  第二步:导数据

  将新表字段及每条记录更新后内容放到excel中,导入oracle数据库中B表。

  第三步:根据两表关联关系,将B表数据批量更新到A表中。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值