MySQL 触发器的使用和理解
作者:编程江湖浪客 时间:2024-01-17 07:09:10
目录
1.触发器是什么?
2.创建触发器
创建触发器的语法如下:
创建多个执行语句的触发器:
NEW和OLD的使用:
3.使用触发器
1.触发器是什么?
一类特殊的数据库程序,可以监视某种数据的操作(insert/update/delete),并触发相关的操作(insert/update/delete),保护数据的完整性。
个人理解就有点类似于Java的观察者模式,一个对象变化,观察者也跟着做出响应。
Mysql好像是从5.0以后开始支持触发器的。
2.创建触发器
创建触发器我将介绍两种方式:用语句创建,用navicat创建。
创建触发器的语法如下:
CREATE TRIGGER trigger_name trigger_time trigger_event ON tb_name FOR EACH ROW trigger_stmt
trigger_name:触发器的名称
tirgger_time:触发时机,为BEFORE或者AFTER
trigger_event:触发事件,为INSERT、DELETE或者UPDATE
tb_name:表示建立触发器的表明,就是在哪张表上建立触发器
trigger_stmt:触发器的程序体,可以是一条SQL语句或者是用BEGIN和END包含的多条语句
所以可以说MySQL创建以下六种触发器:
BEFORE INSERT,BEFORE DELETE,BEFORE UPDATE
AFTER INSERT,AFTER DELETE,AFTER UPDATE
其中,触发器名参数指要创建的触发器的名字
BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后
FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器
创建多个执行语句的触发器:
CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件
ON 表名 FOR EACH ROW
BEGIN
执行语句列表
END
NEW和OLD的使用:
触发器类型 | new和old的使用 |
insert | new代表新增的数据 |
update | new代表更新后的数据,old代表更新前的数据 |
delete | old代表要删除的数据 |
某一个字段可以用new/lod.字段名
接下来我们创建2个表用来测试:
stu表:主表(被观察者)
DROP TABLE IF EXISTS `stu`;
CREATE TABLE `stu` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'id',
`name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '姓名',
`age` int(11) NULL DEFAULT NULL COMMENT '年龄',
`sort` int(11) NULL DEFAULT NULL COMMENT '排序字段',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 18 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;
stu_log表:触发器关联表(观察者)
DROP TABLE IF EXISTS `stu_log`;
CREATE TABLE `stu_log` (
`id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
`name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`create_time` datetime(0) NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 7 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;
现在我们假设有这样一个业务,在stu表新增和删除数据时,同步在stu_log中记录日志,记录name和时间。
如果不使用触发器,我们就需要编写代码来实现这个需求,但是触发器可以帮我们轻松的实现。
首先我们使用语句来创建一个insert触发器:
DROP TRIGGER IF EXISTS `insert_log`;
delimiter ;;
CREATE TRIGGER `add_log` AFTER INSERT ON `stu` FOR EACH ROW BEGIN
INSERT INTO stu_log(name,create_time) VALUES(new.`name`,now());
END
;;
delimiter ;
执行结果:
然后我们再用navicat创建一个delete触发器:
step1:右键stu表,选择设计表----触发器
step2:如图所示填选,选择删除前触发
step3:在下方定义框内写执行语句,如图 记得点保存!
语句:
begin
INSERT INTO stu_log(name,create_time) VALUES(old.`name`,now());
end
3.使用触发器
测试一下:新增一条数据
insert into stu (name,age) VALUES('李白',36)
查看stu表和stu_log表:
如图,触发器已经生效了!
测试删除一条数据
DELETE from stu where name = '李白'
查看stu表和stu_log表:
如图,触发器已经生效了!
来源:https://www.cnblogs.com/godjoker/p/14442831.html
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Hadoop-3.1.2完全分布式环境搭建过程图文详解(Windows 10)
![](https://img.aspxhome.com/file/2023/3/114693_0s.png)
Python入门教程(二十二)Python的类和对象
GoLand一键上传项目到远程服务器的方法步骤
![](https://img.aspxhome.com/file/2023/1/133981_0s.jpg)
python bmp转换为jpg 并删除原图的方法
Selenium常见八大定位法总结
![](https://img.aspxhome.com/file/2023/2/121642_0s.png)
基于python代码批量处理图片resize
利用Google Ajax Library API加速常用js类库的载入
python代码实现扫码关注公众号登录的实战
![](https://img.aspxhome.com/file/2023/3/66403_0s.png)
IEEE Spectrum 2014编程语言排行榜
![](https://img.aspxhome.com/file/2023/0/130930_0s.png)
用ASP实现分级权限控制
用python对excel查重
pytorch掉坑记录:model.eval的作用说明
Bootstrapvalidator校验、校验清除重置的实现代码(推荐)
如何使用PHP中的字符串函数
细化解析:MySQL 数据库中对XA事务的限制
python 3.6 +pyMysql 操作mysql数据库(实例讲解)
![](https://img.aspxhome.com/file/2023/8/79548_0s.png)
Python程序员鲜为人知但你应该知道的17个问题
vue+AI智能机器人回复功能实现
Windows2012配置SQLServer2014AlwaysOn的图解
![](https://img.aspxhome.com/file/2023/7/96157_0s.png)