Mysql
 sql >> Base de données >  >> RDS >> Mysql

Déclencheur de base de données croisée dans MySQL

Oui, vous pouvez. Vous pouvez créer une procédure et l'appeler dans votre déclencheur. Exemple de procédure :

DELIMITER //

CREATE PROCEDURE delete(in table VARCHAR(300), in db VARCHAR(300), in id INT)
BEGIN

set @query0 = CONCAT('DELETE FROM ', new_db, '.', tabela, ' WHERE id=',id);

PREPARE select_query0 FROM @query0;
EXECUTE select_query0;
DEALLOCATE PREPARE select_query0;

END; //

DELIMITER ;

Et ensuite pour créer le déclencheur :

CREATE TRIGGER del_trigger BEFORE DELETE ON table
  FOR EACH ROW BEGIN
    CALL delete(db, table, OLD.id); 
  END;