MySql触发器讲解及使用案例

1.什么是触发器

触发器(trigger):监视某种情况,并进行某种操作,它的执行并不是程序调用,也不是手工启动,而是由事件来触发,例如:对一张表进行操作(插入,更新,删除)时,就会触发执行事先编辑好的若干条SQL语句。

2.触发器的特点与作用

触发器里面的sql语句是一个事务,具有原子性,要么全部执行,要么全部不执行。

3.触发器的创建

使用navicat工具,右键点击表>设计表>触发器>添加触发器;

在这里设置触发时机,和sql语句

sql语句写在 BEGIN 和 END中间

4.NEWOLD的使用

MySQL中定义了NEW OLD 两个临时表,用来表示触发器的所在表中,触发了触发器的哪一行数据,用来引用触发器中发生变化的记录内容

1.在 inster 触发器中,NEW 用来拦截并保存将要(before)或者已经(after) 插入的数据

2.在 update 触发器中,OLD用来拦截并保存将要或已经修改的原数据NEW用来拦截并保存将要或已经修改的为新的数据

3.在delete 触发器中,OLD用来拦截并保存将要或或者已经被删除的原数据

5.使用案例

例如:我们用一张班级表,一张学生表

场景一:我门往学生表增加成员时,触发给对应的班级表人数+1

创建班级表:

 学生表:

 学生表通过classID字段关联班级表

编写触发器:

右键student表>设计表>触发器

然后设置触发规则,我们设置在插入之后,即学生人数增加之后给对应班级人数+1

 更新条件为:班级id 等于 插入后数据classID字段的值

BEGIN
	update class set number = number+1 where id = NEW.classID;
END

此时我们创建一个班级,人数为0

 

 然后在学生表添加一个学生,所在班级为1001

然后我们在返回class班级表,刷新一下数据,会发新此时的班级人数为1

 

 场景二:如果学生姓名叫做 小魔仙,则不允许插入

创建触发器,选择数据插入之前触发该事件,如果插入数据studentName字段值等于 小魔仙 ,则提示请正确输入您的姓名;

 

BEGIN
	IF (NEW.studentName = '小魔仙') THEN 
		SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '请正确输入您的姓名';
	END IF;
END

然后再次插入数据就会显示该提示信息,并不运行插入

 

  • 21
    点赞
  • 155
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

彭白鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值