oracle 触发器 upsert,oracle - Oracle upsert触发错误“ ORA-00036:超过最大递归SQL级别(50)” - 堆栈内存溢出...

首先使用sql%rowcount而不是sql%notfound 。 对于更新sql%notfound,alwasy为false。

其次,您的触发器是递归的。

触发器在表D2C_EVENT_GENERATION_BOM上

1.如果sql%rowcount = 0,则插入D2C_EVENT_GENERATION_BOM

2.触发器执行插入操作(从点1开始),仍然有sql%rowcount = 0,然后插入...

并将此模式重复50次。

要解决此问题,您必须通知下一个触发器中断递归。 最简单的方法是添加前缀并进行检查。

create or replace TRIGGER "BL_D2C_EVENT_GENERATION_BOM"

BEFORE INSERT

ON D2C_EVENT_GENERATION_BOM REFERENCING NEW AS NEW OLD AS OLD

FOR EACH ROW

BEGIN

if :NEW.vibki not like '-%' then

UPDATE D2C_EVENT_GENERATION_BOM SET vibki = :NEW.vibki, status = 'NEW', lastruntime = sysdate

WHERE vibki = :NEW.vibki;

IF ( sql%rowcount = 0 ) THEN

INSERT INTO D2C_EVENT_GENERATION_BOM (vibki,status,lastruntime)

VALUES ('-'||:NEW.vibki,'NEW

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值