触发器是和表关联的特殊的存储过程,可以在插入,删除或修改表中的数据时触发执行,比数据库本身标准的功能有更精细和复杂的数据控制能力。
触发器的优点:
安全性、
审计:可以跟踪用户对数据库的操作;
实现复杂的数据完整性规则、
提供了运行计划任务的另一个方法。
二、MySQL中使用触发器
触发器的四要素:
监控地点:table
监控事件:insert、update、delete
触发时间:after/before
触发事件:insert/update/delete
1、创建触发器
创建触发器的基本语法如下所示:
CREATE TRIGGER trigger_name trigger_time trigger_event ON tb_name FOR EACH ROW trigger_stmt
trigger_name:触发器的名称;
tirgger_time:触发时机,为 BEFORE 或者 AFTER;
trigger_event:触发事件,为 INSERT、DELETE 或者 UPDATE;
tb_name:表示建立触发器的表名,在哪张表上建立触发器;
trigger_stmt:触发器的程序体,可以是一条 SQL 语句或者是用 BEGIN 和 END 包含的多条语句;
FOR EACH ROW 表示任何一条记录上的操作满足触发事件都会触发该触发器
对同一个表相同触发时间的相同触发事件,只能定义一个触发器。
一张表可以定义六个触发器。
-- 删除之前的触发器
drop trigger if exists mytg1
-- 查看触发器
show trigger;