热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Oracle11gmergeintologerror及并行注意事项

nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd

最近有一个业务使用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;
ORA-12801: 并行查询服务器 P000 中发出错误信号
ORA-00001: 违反唯一约束条件 (TEST.SYS_C0011594)
ORA-06512: 在 line 14

解决方案是:加一个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) noappend*/ 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;


推荐阅读
  • 本文详细介绍了在 Oracle 数据库中使用 MyBatis 实现增删改查操作的方法。针对查询操作,文章解释了如何通过创建字段映射来处理数据库字段风格与 Java 对象之间的差异,确保查询结果能够正确映射到持久层对象。此外,还探讨了插入、更新和删除操作的具体实现及其最佳实践,帮助开发者高效地管理和操作 Oracle 数据库中的数据。 ... [详细]
  • 一个建表一个执行crud操作建表代码importandroid.content.Context;importandroid.database.sqlite.SQLiteDat ... [详细]
  • php更新数据库字段的函数是,php更新数据库字段的函数是 ... [详细]
  • 在什么情况下MySQL的可重复读隔离级别会导致幻读现象? ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • 在使用 Cacti 进行监控时,发现已运行的转码机未产生流量,导致 Cacti 监控界面显示该转码机处于宕机状态。进一步检查 Cacti 日志,发现数据库中存在 SQL 查询失败的问题,错误代码为 145。此问题可能是由于数据库表损坏或索引失效所致,建议对相关表进行修复操作以恢复监控功能。 ... [详细]
  • 本文深入探讨了NoSQL数据库的四大主要类型:键值对存储、文档存储、列式存储和图数据库。NoSQL(Not Only SQL)是指一系列非关系型数据库系统,它们不依赖于固定模式的数据存储方式,能够灵活处理大规模、高并发的数据需求。键值对存储适用于简单的数据结构;文档存储支持复杂的数据对象;列式存储优化了大数据量的读写性能;而图数据库则擅长处理复杂的关系网络。每种类型的NoSQL数据库都有其独特的优势和应用场景,本文将详细分析它们的特点及应用实例。 ... [详细]
  • Oracle字符集详解:图表解析与中文乱码解决方案
    本文详细解析了 Oracle 数据库中的字符集机制,通过图表展示了不同字符集之间的转换过程,并针对中文乱码问题提供了有效的解决方案。文章深入探讨了字符集配置、数据迁移和兼容性问题,为数据库管理员和开发人员提供了实用的参考和指导。 ... [详细]
  • 本文详细介绍了使用 Python 进行 MySQL 和 Redis 数据库操作的实战技巧。首先,针对 MySQL 数据库,通过 `pymysql` 模块展示了如何连接和操作数据库,包括建立连接、执行查询和更新等常见操作。接着,文章深入探讨了 Redis 的基本命令和高级功能,如键值存储、列表操作和事务处理。此外,还提供了多个实际案例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • MySQL索引详解及其优化策略
    本文详细解析了MySQL索引的概念、数据结构及管理方法,并探讨了如何正确使用索引以提升查询性能。文章还深入讲解了联合索引与覆盖索引的应用场景,以及它们在优化数据库性能中的重要作用。此外,通过实例分析,进一步阐述了索引在高读写比系统中的必要性和优势。 ... [详细]
  • MySQL Decimal 类型的最大值解析及其在数据处理中的应用艺术
    在关系型数据库中,表的设计与SQL语句的编写对性能的影响至关重要,甚至可占到90%以上。本文将重点探讨MySQL中Decimal类型的最大值及其在数据处理中的应用技巧,通过实例分析和优化建议,帮助读者深入理解并掌握这一重要知识点。 ... [详细]
  • C# 中 SQLite 报错:在 "\\s\\" 附近出现语法错误,如何解决? ... [详细]
  • PTArchiver工作原理详解与应用分析
    PTArchiver工作原理及其应用分析本文详细解析了PTArchiver的工作机制,探讨了其在数据归档和管理中的应用。PTArchiver通过高效的压缩算法和灵活的存储策略,实现了对大规模数据的高效管理和长期保存。文章还介绍了其在企业级数据备份、历史数据迁移等场景中的实际应用案例,为用户提供了实用的操作建议和技术支持。 ... [详细]
  • 本文详细介绍了Oracle数据库中的表空间及其分区技术。表空间作为Oracle数据库的一个逻辑单元,每个数据库可包含一个或多个表空间,每个表空间则关联一个或多个数据文件。通过合理的表空间管理和分区策略,可以显著提升数据库的性能和管理效率。文章还总结了实际应用中的最佳实践,为读者提供了宝贵的参考。 ... [详细]
  • 在CentOS上部署和配置FreeSWITCH
    在CentOS系统上部署和配置FreeSWITCH的过程涉及多个步骤。本文详细介绍了从源代码安装FreeSWITCH的方法,包括必要的依赖项安装、编译和配置过程。此外,还提供了常见的配置选项和故障排除技巧,帮助用户顺利完成部署并确保系统的稳定运行。 ... [详细]
author-avatar
蔡士奇佳霖哲维
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有