0

各挿入コマンドで派生属性を計算するトリガーを作成しようとしています。ただし、コンパイルエラーが発生しますが、どこに問題があるのか​​わかりません。

CREATE OR REPLACE TRIGGER NewTrigger 
BEFORE INSERT 
ON Dates FOR EACH ROW 
 BEGIN 
   SET :NEW.difference := :NEW.date1 - :NEW.date2; 
 END;

エラーを表示すると、この情報が表示されます。

LINE/COL ERROR
-------- -----------------------------------------------------------------
1/7  PL/SQL: SQL Statement ignored
1/11     PL/SQL: ORA-00922: missing or invalid option
4

2 に答える 2

2

トリガーではなく、データ型です。別の日付から日付を減算すると、結果は間隔であり、別の日付ではありません。

CREATE TABLE dates (date1 DATE, date2 DATE, datediff DATE, numdiff NUMBER);
INSERT INTO dates (date1, date2) VALUES (sysdate, sysdate-1);

UPDATE dates SET numdiff = date1 - date2;
1 rows updated

UPDATE dates SET datediff = date1 - date2;
SQL Error: ORA-00932: inconsistent datatypes: expected DATE got DATE JULIAN

したがって、トリガーが間隔を数値で格納する場合、コンパイルは次のようになります。

CREATE OR REPLACE TRIGGER newtriggernum
  BEFORE INSERT ON dates FOR EACH ROW
BEGIN
  :new.numdiff := :new.date1 - :new.date2;
END;
/
TRIGGER NEWTRIGGERNUM compiled

間隔を日付に格納する場合、次のことはしません。

CREATE OR REPLACE TRIGGER newtriggerdate
  BEFORE INSERT ON dates FOR EACH ROW
BEGIN
  :new.datediff := :new.date1 - :new.date2;
END;
/
Error(2,11): PL/SQL: ORA-00922: missing or invalid option
于 2012-12-18T14:28:11.863 に答える
0
CREATE OR REPLACE TRIGGER NewTrigger
BEFORE INSERT ON Dates FOR EACH ROW
BEGIN 
    :NEW.difference := :NEW.date1 - :NEW.date2;
End;
/
于 2012-12-18T13:42:57.907 に答える