网站首页 > 教程分享 正文
1.什么是触发器
触发器(trigger):监视某种情况,并进行某种操作,它的执行并不是程序调用,也不是手工启动,而是由事件来触发,例如:对一张表进行操作(插入,更新,删除)时,就会触发执行事先编辑好的若干条SQL语句。
2.触发器的特点与作用
触发器里面的sql语句是一个事务,具有原子性,要么全部执行,要么全部不执行。
3.触发器的创建
使用navicat工具,右键点击表>设计表>触发器>添加触发器;
在这里设置触发时机,和sql语句
sql语句写在 BEGIN 和 END中间
4.NEW和OLD的使用
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
然后再次插入数据就会显示该提示信息,并不运行插入
猜你喜欢
- 2024-09-09 SQL Server优化50法(sql server 优化)
- 2024-09-09 SQLServer-高级篇(sqlserver ag)
- 2024-09-09 2022-12-17:订单最多的客户。以下数据,结果输出3。请问sql语句
- 2024-09-09 springboot整合mybatis使用xml实现sql语句的查询配置
- 2024-09-09 Qt的数据库(Driver类、Query类、Model类、View类)
- 2024-09-09 VBA+ADO+SQL语句,小试牛刀。(vba的sql)
- 2024-09-09 MS SQL Server——SQL语句导入导出大全
- 2024-09-09 mysql根据条件执行sql(mysql根据条件查询)
- 2024-09-09 MyBatis3-动态SQL语句(navicat怎么写sql语句)
- 2024-09-09 SQL优化——IN和EXISTS谁的效率更高
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- css导航条 (66)
- sqlinsert (63)
- js提交表单 (60)
- param (62)
- parentelement (65)
- jquery分享 (62)
- check约束 (64)
- curl_init (68)
- sql if语句 (69)
- import (66)
- chmod文件夹 (71)
- clearinterval (71)
- pythonrange (62)
- 数组长度 (61)
- javafx (59)
- 全局消息钩子 (64)
- sort排序 (62)
- jdbc (69)
- php网页源码 (59)
- assert h (69)
- httpclientjar (60)
- postgresql conf (59)
- winform开发 (59)
- mysql数字类型 (71)
- drawimage (61)
本文暂时没有评论,来添加一个吧(●'◡'●)