MySQL触发器
- 1、什么是触发器
- 2、创建触发器
- 3、查看所有的触发器
- 4、删除触发器
- 5、常见的触发器案例
- 6、存储过程与触发器的区别
1、什么是触发器
简单点来说触发器就是一个特殊的存储过程,不过存储过程需要手动调用,而触发器自动调用。
一张图来简单说明触发器:
触发器:触发器是数据库中针对数据库表操作触发的一种特殊的存储过程。
2、创建触发器
delimiter $$
create trigger 数据库名.触发器名
before/after -- 触发器执行的顺序
insert/update/delete -- 触发事件
on 数据库名.表名 -- 事件表
for each row
begin
触发器内容 -- 事件触发后要写的语句
end $$
delimiter ;
说明:
触发器触发时间分为before和after两种
主要针对表的增删改操作,可单独指定,也可全部指定。
eg:
delimiter $$
create trigger trig_delstu_delsc
before delete on student for each row
begin
-- old 已经存在于数据库中的数据
-- new 还不存在于数据库中的数据
delete from sc where sid = old.sid;
end $$
delimiter ;
3、查看所有的触发器
SELECT * FROM information_schema.`TRIGGERS`
WHERE trigger_schema = ‘库名'
4、删除触发器
DROP TRIGGER 触发器名
5、常见的触发器案例
利用触发器映射部门表中每个部门的总人数和平均工资,步骤:
1、创建部门表,包含字段部门编号,部门名称,部门人数和平均工资;
2、创建触发器;
3、分别执行DML语句验证。
利用触发器记录删除的数据,并保存在删除表中,步骤:
1、创建删除记录表;
2、创建触发器;
3、执行DELETE语句验证。
6、存储过程与触发器的区别
- 语法:存储过程procedure,触发器trigger
- 执行:存储过程需要调用菜执行,触发器自动执行
- 返回值:存储过程可以定义返回值,触发器没有返回值
- 功能:存储过程是一组特定功能的SQL语句,触发器则是SQL语句前后执行,本身不影响原功能。