您的位置 首页 > 资格资历

mysql触发器?MySql触发器讲解及使用案例

各位老铁们好,相信很多人对mysql触发器都不是特别的了解,因此呢,今天就来为大家分享下关于mysql触发器以及MySql触发器讲解及使用案例的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!

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

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

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

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

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

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

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

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

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

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

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

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

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

BEGIN\n\nupdateclasssetnumber=number+1whereid=NEW.classID;\n\nEND

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

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

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

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

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

BEGIN\n\nIF(NEW.studentName='小魔仙')THEN\n\nSIGNALSQLSTATE'45000'SETMESSAGE_TEXT='请正确输入您的姓名';\n\nENDIF;\n\nEND

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

mysql触发器和MySql触发器讲解及使用案例的问题分享结束啦,以上的文章解决了您的问题吗?欢迎您下次再来哦!

本站涵盖的内容、图片、视频等数据,部分未能与原作者取得联系。若涉及版权问题,请及时通知我们并提供相关证明材料,我们将及时予以删除!谢谢大家的理解与支持!

Copyright © 2023