在MySQL中执行DELETE操作后触发触发器

执行DELETE操作后,使用AFTER DELETE触发触发器。以下是语法-

DELIMITER //
   CREATE TRIGGER yourTriggerName
      AFTER DELETE
      ON yourTableName FOR EACH ROW
      BEGIN
      yourStatement1,
      .
      .
      N
   END;
   //

让我们首先创建一个表-

mysql> create table DemoTable(Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,FirstName varchar(100));

使用插入命令在表中插入一些记录-

mysql> insert into DemoTable(FirstName) values('John');
mysql> insert into DemoTable(FirstName) values('Mike');

使用select语句显示表中的所有记录-

mysql> select *from DemoTable;

这将产生以下输出-

+----+-----------+
| Id | FirstName |
+----+-----------+
| 1  | John      |
| 2  | Mike      |
+----+-----------+
2 rows in set (0.00 sec)

以下是创建触发器并使用AFTER DELETE的查询-

mysql> DELIMITER //
mysql> CREATE TRIGGER history_of_Table
   AFTER DELETE
      ON DemoTable FOR EACH ROW
   BEGIN
      SELECT USER() INTO @userName;
      SELECT NOW() INTO @deleteDatetime;
   END; //
mysql> DELIMITER ;

要检查触发器是否正常工作,请从表中删除第一条记录:

mysql> delete from DemoTable where Id=1;

上面,我们从表中删除了第一条记录。这意味着使用DELETE命令后触发器必须处于活动状态-

mysql> select @userName;

这将产生以下输出-

+----------------+
| @userName      |
+----------------+
| root@localhost |
+----------------+
1 row in set (0.00 sec)

每当触发器起作用时,它将显示当前时间-

mysql> select @deleteDatetime;

这将产生以下输出-

+---------------------+
| @deleteDatetime     |
+---------------------+
| 2019-07-09 21:06:31 |
+---------------------+
1 row in set (0.00 sec)