我是靠谱客的博主 安详酸奶,最近开发中收集的这篇文章主要介绍Mysql高级-触发器触发器,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

触发器

触发器是一种特殊的存储过程,他不需要用户去直接调用,而是在对表增删改后自动执行的存储过程。

特点:

  1. 与表关联。定义在指定表上,这个表被称为触发器表。
  2. 自动激活触发器。当对表中的数据执行增、删、改操作时,如果对表上的这个特定操作定义了触发器,该触发器自动执行,这时不可撤销的。
  3. 不能直接调用。与存储过程不同,触发器不能直接调用,也不能传递或接收参数。
  4. 作为事务的一部分。触发器与激活触发器的语句一起作为对一个单一事务来对待,可以从触发器中的任何位置回滚。

定义触发器的语法规则

create trigger 触发器名 触发时机 触发事件
on 表名称
for each row(行级触发)
begin
	语句
end;
语法解析:
1.触发器名称:用来表示触发器。
2.触发时机:before或after。
3.触发事件:对表的插入、修改或删除操作。
4.表名称:标识建立触发器的表名,即在哪张表上建立触发器。
5.语句:触发器程序体,begin和end作为开始和结束,中间包含多条语句。

例:

1.删除用户时,自动触发删除用户角色关系

create 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.新增用户时,自动向日志表插入数据

create 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高级-触发器触发器所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(53)

评论列表共有 0 条评论

立即
投稿
返回
顶部