阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

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

380次阅读
没有评论

共计 3011 个字符,预计需要花费 8 分钟才能阅读完成。

最近有一个业务使用 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 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-01/139745.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3011字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7803204
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

  告别 Notion 焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁” 引言 在数字笔记工...
浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍 前言 在 AI 自动化快速发展的当下,浏览器早已不再只是...
多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞...
终于收到了以女儿为原型打印的3D玩偶了

终于收到了以女儿为原型打印的3D玩偶了

终于收到了以女儿为原型打印的 3D 玩偶了 前些日子参加某网站活动,获得一次实物 3D 打印的机会,于是从众多...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
开发者福利:免费 .frii.site 子域名,一分钟申请即用

开发者福利:免费 .frii.site 子域名,一分钟申请即用

  开发者福利:免费 .frii.site 子域名,一分钟申请即用 前言 在学习 Web 开发、部署...
把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地 大家好,我是星哥,今天教大家在飞牛 NA...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛 NAS-12:开源笔记的进化之路,效率玩家的新选择 前言 如何高效管理知识与笔记,已经成为技术...
自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个 AI 智能体 — 跟创业大佬对话 前言 智能体(Agent)已经成为创业者和技术人绕...