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

Oprettelse af trigger, der kører på to borde

Dette fungerede 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. Forskellen mellem BYTE og CHAR i kolonnedatatyper

  2. CONCAT_WS() til SQL Server

  3. MariaDB POWER() Forklaret

  4. SequelizeJS - hasMany to hasMany på samme bord med et joinbord