• Oracle并行更新的两种方式(merge/update内联视图)


    对于Oracle的两表联合更新的场景(有AB两表,以A.id=B.id关联,根据B表中的记录更新A表中的相应字段),一般有update内联视图和merge两种方式,下面举例介绍:

     

    创建用例表:

    create table test1(id number(10),name varchar2(20));

    create table test2(id number(10),name varchar2(20));

     

    测试数据:

    begin

    insert into test1 values(1,'A');

    insert into test1 values(2,'B');

     

    insert into test2 values(1,'C');

    insert into test2 values(2,'D');

    end;

     

     

    merge方式:

    merge into test1 using test2

    on (test1.id = test2.id)

    when matched then update

    set test1.name = nvl2(test1.name,test2.name,test1.name);

     

    merge方法是最简洁,效率最高的方式,在大数据量更新时优先使用这种方式。

     

     

    update内联视图方式:

    使用这种方式必须在test2.id上有主键(这里很好理解,必须保证每一个test1.id对应在test2里只有一条记录,如果test2中有多条对应的记录,怎么更新test1?),一般而言这种方式代价比merge方式稍高。

    alter table test2 add constraint pk_test2 primary key(id);  --/*+ BYPASS_UJVC */

     

    update (select /*+ BYPASS_UJVC */a.id aid,a.name aname,b.id bid,b.name bname from test1 a,test2 b where a.id=b.id) t

    set aname = nvl2(aname,bname,aname);

     

     

     

    使用并行,加快大量数据更新:

    merge /*+parallel(test1,4)*/ into test1 using test2

    on (test1.id = test2.id)

    when matched then update

    set test1.name = nvl2(test1.name,test2.name,test1.name);

  • 相关阅读:
    活学活用wxPython基础框架
    xpython在Windos下的安装及简单的文本打开、保存
    paramiko实现上传目录
    Python3结合paramiko执行命令
    openstry lua redis实现负载均衡
    定时重启tomcat
    简单的生成随机验证码
    第一个Python小项目:图片转换成字符图片
    Python小练习(二)
    Python小练习(一)
  • 原文地址:https://www.cnblogs.com/quanweiru/p/4133682.html
Copyright © 2020-2023  润新知