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 是对应表的行记录类型变量。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值