sql >> Databasteknik >  >> RDS >> Mysql

MySQL-utlösardefinition - 1064-fel

Du måste deklarera din variabel "msg" i din procedur och använda END IF

#START TRIGGER
delimiter //
CREATE TRIGGER passStandard_check BEFORE INSERT ON Module
FOR EACH ROW 
BEGIN 
    DECLARE msg VARCHAR(255); /* << PUT THIS HERE */
    IF NEW.passStandard < 0 || NEW.passStandard > 1 THEN 
        set msg = concat('Trigger Error: Pass Standard: ', cast(NEW.passStandard as char));
        signal sqlstate '45000' set message_text = msg;
    END IF; /* << YOU WILL NEED THIS TOO (DONT FORGET THE SEMICOLON :D) */
END//
delimiter ;
#END TRIGGER


  1. Lagrar Array-värden till heltal

  2. MySQL - Hur man infogar i en tabell som har många-till-många-relation

  3. Finns det någon MySQL Aggregate-funktion för CONTAINS?

  4. returnera en rad i lagrad procedur på oracle