触发器
触发器是一种特殊的存储过程,他不需要用户去直接调用,而是在对表增删改后自动执行的存储过程。
特点:
- 与表关联。定义在指定表上,这个表被称为触发器表。
- 自动激活触发器。当对表中的数据执行增、删、改操作时,如果对表上的这个特定操作定义了触发器,该触发器自动执行,这时不可撤销的。
- 不能直接调用。与存储过程不同,触发器不能直接调用,也不能传递或接收参数。
- 作为事务的一部分。触发器与激活触发器的语句一起作为对一个单一事务来对待,可以从触发器中的任何位置回滚。
定义触发器的语法规则
复制代码
1
2
3
4
5
6
7create trigger 触发器名 触发时机 触发事件 on 表名称 for each row(行级触发) begin 语句 end;
复制代码
1
2
3
4
5
6
7语法解析: 1.触发器名称:用来表示触发器。 2.触发时机:before或after。 3.触发事件:对表的插入、修改或删除操作。 4.表名称:标识建立触发器的表名,即在哪张表上建立触发器。 5.语句:触发器程序体,begin和end作为开始和结束,中间包含多条语句。
例:
1.删除用户时,自动触发删除用户角色关系
复制代码
1
2
3
4
5
6
7
8
9create trigger delete_user_role before delete on user for each row begin delete from user_role where userid = old.id; end -- 测试 delete from user where id = 1;
2.新增用户时,自动向日志表插入数据
复制代码
1
2
3
4
5
6
7
8
9create trigger save_user_log after insert on user for each row begin insert into user_log(id,name)values(new.id,new.account); end; -- 测试 insert into user(account)values('balun');
在行级触发器代码中,可以使用 old 和 new 访问到该行的旧数据和新数据,old 和 new 是对应表的行记录类型变量。
最后
以上就是安详酸奶最近收集整理的关于Mysql高级-触发器触发器的全部内容,更多相关Mysql高级-触发器触发器内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复