sql >> Database teknologi >  >> RDS >> Oracle

SQL PLUS Trigger kompileringsfejl

Det er ikke udløseren, det er datatypen. Hvis du trækker en dato fra en anden dato, er resultatet et interval, ikke en anden dato:

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

Så hvis triggeren gemmer intervallet i et tal, kompilerer den:

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

og hvis den gemmer intervallet i en dato, gør den det ikke:

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


  1. SQL Server 2008 R2 sidder fast i enkeltbrugertilstand

  2. Hvad er levetiden for en PostgreSQL server-side forberedt erklæring

  3. Forslag til sikkerhedskopiering af php site og mysql db

  4. Smuk suppe webscrape ind i mysql