用于设置最小值的Oracle SQL触发器在NULL上为INT字段

时间:2017-01-18 10:16:11

标签: oracle triggers setvalue

我试图在PACKS表上设置触发器,在插入新PACK时设置INT字段中的最小值 - PRICE - 例如' 333'。用于插入调用过程新包。 那就是触发器:

CREATE OR REPLACE TRIGGER pack_min_price
BEFORE
INSERT
ON PACKS
FOR EACH ROW
BEGIN
 IF new.PRICE < 333 THEN
 :new.PRICE := :new.PRICE + 333;
 END IF;
END;

那就是PROCEDURE:

create or replace PROCEDURE newPack(
cntr IN PACKS.COUNTRY%TYPE,
trns IN PACKS.TRANSPORT%TYPE,
htl IN PACKS.HOTEL%TYPE,
extr IN PACKS.HOTELEXTRAS%TYPE,
othextr IN PACKS.OTHEREXTRAS%TYPE,
strdt IN PACKS.STARTDATE%TYPE,
enddt IN PACKS.ENDDATE%TYPE,
prc IN PACKS.PRICE%TYPE)

IS
BEGIN
  INSERT INTO PACKS 
  (COUNTRY,TRANSPORT,HOTEL,HOTELEXTRAS,OTHEREXTRAS,STARTDATE,ENDDATE,PRICE)
VALUES
  (cntr,trns,htl,extr,othextr,strdt,enddt,prc);

COMMIT;

END;

我尝试编译触发器时得到的错误 -

Compilation failed, line 2 (10:12:41) The line numbers associated with compilation errors are relative to the first BEGIN statement. This only affects the compilation of database triggers.
PLS-00201: identifier 'NEW.PRICE' must be declaredCompilation failed, line 2 (10:12:41) The line numbers associated with compilation errors are relative to the first BEGIN statement. This only affects the compilation of database triggers.
PL/SQL: Statement ignored 

当我开始程序时 -

ORA-04098: trigger 'PROJECT160.PACK_MIN_PRICE' is invalid and failed re-validation

没有触发器,程序工作正常。你能帮我吗? THX

1 个答案:

答案 0 :(得分:0)

您在IF语句中的新实例上缺少:

IF :new.PRICE < 333 THEN
    :new.PRICE := :new.PRICE + 333;
END IF;