插入新条目后触发器已创建但无法正常工作。显示ORA-04091错误

时间:2017-03-20 14:20:27

标签: sql oracle oracle11g triggers

我已经创建了触发器,可以根据另一个表中的条目将数据插入到另一个表中。触发器已创建,但在表格中输入值后,会收到以下错误。

  

ORA-04091:表OOMUSER.EMTN_EVC_PAIR_STATUS正在变异,触发/功能可能看不到它

     

ORA-06512:at" OOMUSER.PORTSTATUSUPDATE",第22行

     

ORA-04088:执行触发器时出错' OOMUSER.PORTSTATUSUPDATE'

DROP TRIGGER OOMUSER.PORTSTATUSUPDATE;

CREATE OR REPLACE TRIGGER OOMUSER.PORTSTATUSUPDATE
AFTER INSERT 
ON OOMUSER.EMTN_EVC_PAIR_STATUS     FOR EACH ROW
DECLARE
LEGA VARCHAR2(20);
LEGB VARCHAR2(20);
ACTIVEPAIRA NUMBER;
ACTIVEPAIRB NUMBER;
BEGIN
SELECT EELA.CPE_PORT_SERVICE_ID INTO LEGA FROM EMTN_EVC_LEG_A EELA WHERE EELA.EMTN_EVC_PAIRID = :NEW.EMTN_EVC_PAIRID;
SELECT EELB.CPE_PORT_SERVICE_ID INTO LEGB FROM EMTN_EVC_LEG_B EELB WHERE EELB.EMTN_EVC_PAIRID = :NEW.EMTN_EVC_PAIRID;

IF (:NEW.STATUS = 'Active' OR :NEW.STATUS = 'Planned') 
THEN    
    INSERT INTO OOMUSER.EMTN_ETN_CPE_PORT_STATUS
        (CPE_PORT_SERVICE_ID,STATUS,STATUS_START_DATETIME)
        VALUES(LEGA,:NEW.STATUS,SYSDATE);
    INSERT INTO OOMUSER.EMTN_ETN_CPE_PORT_STATUS
        (CPE_PORT_SERVICE_ID,STATUS,STATUS_START_DATETIME)
        VALUES(LEGB,:NEW.STATUS,SYSDATE);

ELSIF(:NEW.STATUS = 'Rejected' OR :NEW.STATUS = 'Cancelled')
THEN
    SELECT COUNT(OVEDS.EMTN_EVC_PAIRID) INTO ACTIVEPAIRA FROM OOM_VW_EMTN_DUALEVC_STATUS OVEDS WHERE OVEDS.EMTN_EVC_PAIRID IN 
    (
        SELECT EELA.EMTN_EVC_PAIRID FROM EMTN_EVC_LEG_A EELA WHERE EELA.CPE_PORT_SERVICE_ID = 
        (
            SELECT EELA.CPE_PORT_SERVICE_ID FROM EMTN_EVC_LEG_A EELA WHERE EELA.EMTN_EVC_PAIRID = :NEW.EMTN_EVC_PAIRID
        )
    ) AND UPPER(OVEDS.STATUS) IN ('ACTIVE','PLANNED'); 

    IF(ACTIVEPAIRA = 0) 
    THEN
        INSERT INTO OOMUSER.EMTN_ETN_CPE_PORT_STATUS
            (CPE_PORT_SERVICE_ID,STATUS,STATUS_START_DATETIME)
            VALUES(LEGA,:NEW.STATUS,SYSDATE);
    END IF;

    SELECT COUNT(OVEDS.EMTN_EVC_PAIRID) INTO ACTIVEPAIRB FROM OOM_VW_EMTN_DUALEVC_STATUS OVEDS WHERE OVEDS.EMTN_EVC_PAIRID IN 
    (
        SELECT EELB.EMTN_EVC_PAIRID FROM EMTN_EVC_LEG_B EELB WHERE EELB.CPE_PORT_SERVICE_ID = 
        (
            SELECT EELB.CPE_PORT_SERVICE_ID FROM EMTN_EVC_LEG_B EELB WHERE EELB.EMTN_EVC_PAIRID = :NEW.EMTN_EVC_PAIRID
        )
    ) AND UPPER(OVEDS.STATUS) IN ('ACTIVE','PLANNED'); 

    IF(ACTIVEPAIRB = 0) 
    THEN
        INSERT INTO OOMUSER.EMTN_ETN_CPE_PORT_STATUS
            (CPE_PORT_SERVICE_ID,STATUS,STATUS_START_DATETIME)
            VALUES(LEGB,:NEW.STATUS,SYSDATE);
    END IF;

END IF;

END;
/

1 个答案:

答案 0 :(得分:1)

您的错误消息ayss第22行是问题:

  

ORA-06512:at" OOMUSER.PORTSTATUSUPDATE",第22行

确定Trigger Body源代码的行号并不是一门精确的科学,特别是当它被粘贴到StackOverflow中时,line 22表明这一行是麻烦似乎是合理的:

SELECT COUNT(OVEDS.EMTN_EVC_PAIRID) INTO ACTIVEPAIRB FROM OOM_VW_EMTN_DUALEVC_STATUS OVEDS WHERE OVEDS.EMTN_EVC_PAIRID  

OOM_VW_EMTN_DUALEVC_STATUS是一个观点吗?如果是这样,它依赖什么表?我的猜测是EMTN_EVC_PAIR_STATUS功能。