首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ORA-00001: oracle中违反错误的唯一约束

ORA-00001: oracle中违反错误的唯一约束
EN

Stack Overflow用户
提问于 2022-01-26 00:33:39
回答 1查看 586关注 0票数 0

我有这2条jdbc语句(Oracle 10g具有已提交的隔离级别读)

代码语言:javascript
复制
delete from emp where emp_id = 1;
insert into emp (emp_id,address,.....) value (1,'newyork',.....);

emp_id,地址是主键

不幸的是,在多线程环境中,我得到了ORA-00001:在插入记录时违反了唯一约束。

当我在一个线程中运行时,我没有看到任何问题。

经过调查我发现

committed.

  • second
  • 第一次会话删除然后插入记录,但还没有

会话删除它,第一次会话现在提交给它,

  • 第二次会话现在尝试插入它并抛出错误。

如果我遗漏了什么就告诉我。

我不喜欢单线程的解决方案,也不喜欢重试的解决方案。

有干净的溶液吗?

EN

回答 1

Stack Overflow用户

发布于 2022-01-26 01:32:23

确保在程序中启用了AUTOCOMMIT,然后在插入行之前检查该行是否存在,以防止ORA-00001。下面是PL/SQL块。

代码语言:javascript
复制
declare
  v_rows_count number;
begin
  select count(*) into v_rows_count from emp where emp_id = 1;
  if v_rows_count = 0 then
    -- Insert the row
  else
    -- Do not insert the row
  end if;
end;
/

别忘了以后再改。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70857414

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档