点击蓝字关注我吧
【本文详细介绍了数据库中触发器的基本概念和使用方法,欢迎读者朋友们阅读、转发和收藏!】
1 基本概念
1.1 触发器的概述
触发器其实是一种特殊的存储过程。一般的存储过程是通过存储过程名直接调用,而触发器主要是通过事件 ( 增、删、改 ) 进行触发而被执行的,在表中数据发生变化时自动强制执行。
常见的触发器有两种:after(for) 、 instead of, 用于 insert 、 update 、 delete 事件。
after(for) 表示执行代码后,执行触发器
instead of 表示执行代码前,用已经写好的触发器代替你的操作。
1.2 触发器的用法
创建触发器
语法如下
CREATE TRIGGER trigger_name trigger_time trigger_event
ON tbl_name FOR EACH ROW trigger_stmt
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。
触发程序与命名为 tbl_name 的表相关。tbl_name 必须引用永久性表。不能将触发程序与临时表或视图关联起来。
trigger_time 是触发程序的动作时间。它可以是 BEFORE 或 AFTER ,以指明触发程序是在激活它的语句之前或之后触发。
trigger_event 指明了激活触发程序的语句的类型。trigger_event 可以是下述值之一:
• INSERT :将新行插入表时激活触发程序,例如,通过 INSERT 、 LOAD DATA 和 REPLACE 语句。
• UPDATE :更改某一行时激活触发程序,例如,通过 UPDATE 语句。
• DELETE :从表中删除某一行时激活触发程序,例如,通过 DELETE 和 REPLACE 语句。
请注意, trigger_event 与以表操作方式激活触发程序的 SQL 语句并不很类似,这点很重要。
例如,关于 INSERT 的 BEFORE 触发程序不仅能被 INSERT 语句激活,也能被 LOAD DATA 语句激活。
可能会造成混淆的例子之一是 INSERT INTO .. ON DUPLICATE UPDATE ... 语法:BEFORE INSERT 触发程序对于每一行将激活,后跟 AFTER INSERT 触发程序,或 BEFORE UPDATE 和 AFTER UPDATE 触发程序,具体情况取决于行上是否有重复键。
对于具有相同触发程序动作时间和事件的给定表,不能有两个触发程序。
例如,对于某一表,不能有两个 BEFORE UPDATE 触发程序。
但可以有 1 个 BEFORE UPDATE 触发程序和 1 个 BEFORE INSERT 触发程序,或 1 个 BEFORE UPDATE 触发程序和 1 个 AFTER UPDATE 触发程序。
trigger_stmt 是当触发程序激活时执行的语句。
如果你打算执行多个语句,可使用 BEGIN ... END 复合语句结构。这样,就能使用存储子程序中允许的相同语句。
删除触发器
使用 DROP TRIGGER 语句可以删除 MYSQL 中已经定义的触发器。
我知道你在看哟
领取专属 10元无门槛券
私享最新 技术干货