sql >> Databasteknik >  >> RDS >> Mysql

höj applikationsfel Trigger i MySQL DBMS

Din syntax verkar vara MySQL. Och ändå, raise_application_error är en Oracle-konstruktion. Du vill ha signal , dokumenterad här :

DELIMITER @@
DROP TRIGGER IF EXISTS gmtt.after_update_mcorr @@
CREATE TRIGGER gmtt.after_update_mcorr
AFTER UPDATE ON gmtt.mcorr
FOR EACH ROW
BEGIN
   IF OLD.etat = '0' AND NEW.etat = '1' THEN
        INSERT INTO historique(message, User, dateHisto)
             VALUES (CONCAT( 'a achevé la Maintenance ', OLD.codeMaint) , CURRENT_USER(), NOW()); 
   ELSE
       signal sqlstate '-20000' set message_text = 'Pay is below Texas minimum wage!';     
   END IF;
END @@ 
DELIMITER ;



  1. PHP INFOGA ett variabelt antal poster till mysql från ett html-formulär

  2. Låser INSERT IGNORE tabellen även om den ignorerar infogningen?

  3. Uppgradering av MariaDB 10.0 till 10.3.9 på Ubuntu 16.04

  4. Hur lagrar man varbinary i MySQL?