当前位置:  数据库>oracle

Oracle 11g merge into log error及并行注意事项

    来源: 互联网  发布时间:2017-06-26

    本文导语: 最近有一个业务使用merge into报主键冲突的错误。各地市将数据汇总到省,省的数据是按照局编码分区,由于不同的地市,有主键相同的数据,应该是垃圾数据。 --初始化数据 drop table T_LIST purge;drop table T_LIST1 purge; CREATE TABLE T_LIST...

最近有一个业务使用merge into报主键冲突的错误。各地市将数据汇总到省,省的数据是按照局编码分区,由于不同的地市,有主键相同的数据,应该是垃圾数据。

--初始化数据

drop table T_LIST purge;
drop table T_LIST1 purge;
 CREATE TABLE T_LIST
 (
    ID  NUMBER(7) NOT NULL PRIMARY KEY,
    CITY VARCHAR2(10),
    sort number
 )
 PARTITION BY LIST (CITY)
 (
      PARTITION P_BEIJING  VALUES ('BEIJING') ,
      PARTITION P_SHANGHAI VALUES ('SHANGHAI'),
      PARTITION P_GUANGZHOU VALUES ('GUANGZHOU')
 );
 insert into T_LIST values(1,'BEIJING',11);
 insert into T_LIST values(2,'SHANGHAI',22);
 insert into T_LIST values(3,'GUANGZHOU',33);
 commit;

 CREATE TABLE T_LIST1
 (
    ID  NUMBER(7) PRIMARY KEY,
    CITY VARCHAR2(10),
    sort number
 )
 PARTITION BY LIST (CITY)
 (
      PARTITION P_BEIJING  VALUES ('BEIJING') ,
      PARTITION P_SHANGHAI VALUES ('SHANGHAI'),
      PARTITION P_GUANGZHOU VALUES ('GUANGZHOU')
 );
 insert into T_LIST1 values(1,'BEIJING',111);
 insert into T_LIST1 values(3,'SHANGHAI',222);
 insert into T_LIST1 values(2,'GUANGZHOU',333);
 commit;
--建立错误日志表
EXEC DBMS_ERRLOG.CREATE_ERROR_LOG('T_LIST', 'T_ERROR_LOG');

 declare
    Type city is table of varchar2(10);
    v_city city := city('BEIJING', 'SHANGHAI', 'GUANGZHOU');
    V_SQL  VARCHAR2(4000) :=
 'merge into T_LIST a using(select * from T_LIST1 where CITY = :1) b
 on (a.id =  b.id and a.city =  b.city and a.city = :2)
 when matched then
  update set a.sort=b.sort
 when not matched then
  insert values(b.id,b.city,b.sort) LOG ERRORS INTO T_ERROR_LOG REJECT LIMIT  UNLIMITED';
 begin
      for i in v_city.first .. v_city.last loop   
      execute immediate V_SQL using v_city(i),v_city(i);
      end loop;
      commit;
 end;


 SQL> select ORA_ERR_MESG$,id,city from T_ERROR_LOG;
 ORA_ERR_MESG$                                      ID        CITY
 -------------------------------------------------- ---------- ----------
 ORA-00001: 违反唯一约束条件 (TEST.SYS_C0011594)    3          SHANGHAI
 
ORA-00001: 违反唯一约束条件 (TEST.SYS_C0011594)    2          GUANGZHOU

当然,在数据量大的情况下要使用并行,有可能会有问题,因为并行默认是直接路径读。

alter session enable parallel dml;
 declare
    Type city is table of varchar2(10);
    v_city city := city('BEIJING', 'SHANGHAI', 'GUANGZHOU');
    V_SQL  VARCHAR2(4000) :=
 'merge /*+parallel(2) */ into T_LIST a using(select * from T_LIST1 where CITY = :1) b
 on (a.id =  b.id and a.city =  b.city and a.city = :2)
 when matched then
  update set a.sort=b.sort
 when not matched then
  insert values(b.id,b.city,b.sort) LOG ERRORS INTO T_ERROR_LOG REJECT LIMIT UNLIMITED';
 begin
      for i in v_city.first .. v_city.last loop
      execute immediate V_SQL using v_city(i),v_city(i);
      commit;
      end loop;
 end;


解决方案是:加一个noappend的hint,并行也可以改为merge /*+parallel(a)  parallel(b) noappend*/ into.
 declare
    Type city is table of varchar2(10);
    v_city city := city('BEIJING', 'SHANGHAI', 'GUANGZHOU');
    V_SQL  VARCHAR2(4000) :=
 'merge /*+parallel(2) */ into T_LIST a using(select * from T_LIST1 where CITY = :1) b
 on (a.id =  b.id and a.city =  b.city and a.city = :2)
 when matched then
  update set a.sort=b.sort
 when not matched then
  insert values(b.id,b.city,b.sort) LOG ERRORS INTO T_ERROR_LOG REJECT LIMIT UNLIMITED';
 begin
      for i in v_city.first .. v_city.last loop
      execute immediate V_SQL using v_city(i),v_city(i);
      commit;
      end loop;
 end;


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3