sql >> Databasteknik >  >> RDS >> Oracle

Skapar trigger som körs på två bord

Detta fungerade perfekt.

CREATE OR REPLACE TRIGGER checkDuration
  BEFORE INSERT OR UPDATE on offering
  FOR EACH ROW
DECLARE
  isFound NUMBER;
BEGIN
  SELECT 1 INTO isFound FROM DUAL WHERE EXISTS (
    SELECT * FROM Course c
    WHERE c.courseId = :new.courseId AND c.duration = 5);
  IF EXTRACT(MONTH FROM :new.startDate) = 12 
    THEN RAISE_APPLICATION_ERROR(-20001, 'Courses of five days duration cannot be run in December');
  END IF;
EXCEPTION
  WHEN NO_DATA_FOUND THEN
    NULL;
END;


  1. Kan jag tvinga mysql att utföra subquery först?

  2. NHibernate QueryOver och MYSQL

  3. SQL Server gruppera efter antal datum och tid per timme?

  4. Hur har man fullständig offlinefunktionalitet i en webbapp med PostgreSQL-databas?