?? 个人主页:黄小黄的博客主页
支持我:?? 点赞 ?? 收藏 ??关注
?? 格言:一步一个脚印才能承接所谓的幸运本文来自专栏:MySQL8.0学习笔记
本文参考视频:MySQL数据库全套教程
欢迎点击支持订阅专栏
?? 触发器介绍:
?? 触发器示意图:
触发器定义在表上,附着在表上。
触发器在定义时,需要指定:
1.创建只有一个执行语句的触发器:
create trigger 触发器名 before|after 触发事件
on 表名 for each row
执行语句;
2.创建有多个执行语句的触发器:
create trigger 触发器名 before|after 触发事件
on 表名 for each row
begin
执行语句列表
end;
首先进行数据准备,定义两个表user与user_logs,分别记录用户注册信息和用户操作日志。希望当user发生变化时,user_logs自动发生变化(通过触发器实现)。 数据准备相关代码如下:
CREATE DATABASE IF NOT EXISTS mydatabase_tigger;
USE mydatabase_tigger;
-- 用户表创建
CREATE TABLE user(
uid INT PRIMARY KEY ,
username VARCHAR(50) NOT NULL ,
password VARCHAR(50) NOT NULL
);
-- 用户信息操作日志表
CREATE TABLE user_logs(
id INT PRIMARY KEY AUTO_INCREMENT,
time TIMESTAMP,
log_text VARCHAR(255)
);
若希望给user表添加信息时,user_logs表自动添加一行数据,在下面代码中定义了一个触发器trigger_test01来实现需求,相关代码与结果如下:
CREATE TRIGGER trigger_test01
AFTER INSERT
ON user
FOR EACH ROW
INSERT INTO user_logs
VALUES (NULL, NOW(), ‘新用户添加’);
INSERT INTO user VALUES (1, ‘nezuko’, ‘123456’);
当user表数据被修改时,自动在user_logs添加日志记录。,在下面代码中定义了一个触发器trigger_test02来实现需求,相关代码与结果如下:
DELIMITER
C
R
E
A
T
E
T
R
I
G
G
E
R
t
r
i
g
g
e
r
t
e
s
t
02
B
E
F
O
R
E
U
P
D
A
T
E
O
N
u
s
e
r
F
O
R
E
A
C
H
R
O
W
B
E
G
I
N
I
N
S
E
R
T
I
N
T
O
u
s
e
r
l
o
g
s
V
A
L
U
E
S
(
N
U
L
L
,
N
O
W
(
)
,
′
用户信息被修
改
′
)
;
E
N
D
CREATE TRIGGER trigger_test02 BEFORE UPDATE ON user FOR EACH ROW BEGIN INSERT INTO user_logs VALUES (NULL, NOW(), '用户信息被修改'); END
CREATETRIGGERtriggertest02BEFOREUPDATEONuserFOREACHROWBEGININSERTINTOuserlogsVALUES(NULL,NOW(),′用户信息被修改′);END
DELIMITER ;
UPDATE user SET password = ‘111111’ WHERE uid = 1;
可以看到 user表中的密码被修改,日志表中成功添加了修改信息的记录。
MySQL中定义了NEW和OLD,用来表示触发器所在表中,触发了触发器哪一行数据,来引用触发器中发生变化的记录内容, 具体见下表:
触发器类型
触发器类型NEW与OLD的使用
INSERT型触发器
NEW表示将要或者已经新增的数据
UPDATE型触发器
OLD表示修改之前的数据,NEW表示将要或者已经修改后的数据
DELETE型触发器
OLD表示将要或者已经删除的数据
?? 使用方法:
NEW.columnName(columnName表示相应数据的某一列名)
何种需求下会使用到NEW和OLD呢?
在上面举例的案例中,我们修改user表中的密码,给user_logs表中添加了修改信息。但是仅仅提示了修改了信息,并没有指明。假如,在信息中需要指明修改前的密码或者修改后的密码,则需要使用到OLD和NEW用于触发器来引用数据!
定义触发器trigger_test03,可以给user_logs插入修改信息,展示用户修改前的密码和修改后的密码。相关代码和结果如下:
DELIMITER $$
CREATE TRIGGER trigger_test03
BEFORE UPDATE
ON user
FOR EACH ROW
BEGIN
INSERT INTO user_logs VALUES (NULL, NOW(), CONCAT('用户信息被修改,修改前的密码为', OLD.password, ',修改后为', NEW.password));
END $$
DELIMITER ;
UPDATE user SET password = '99999999' WHERE uid = 1;
如果希望删除触发器,则可以使用下面的语句: 删除到目前为止创建的三个触发器。
DROP TRIGGER IF EXISTS trigger_test01;
DROP TRIGGER IF EXISTS trigger_test02;
DROP TRIGGER IF EXISTS trigger_test03;
查看触发器:
show triggers;
删除触发器:
drop trigger if exists trigger_name;
??以上便是本文的全部内容啦,后续内容将会持续免费更新,如果文章对你有所帮助,麻烦动动小手点个赞 + 关注,非常感谢 !
如果有问题,欢迎私信或者评论区!
共勉:“你间歇性的努力和蒙混过日子,都是对之前努力的清零。”
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦