当前位置:网站首页>【MySQL】数据库进阶之触发器内容详解
【MySQL】数据库进阶之触发器内容详解
2022-07-07 06:00:00 【小黄小黄不再迷茫】
个人主页:黄小黄的博客主页
️ 支持我: 点赞 收藏 关注
格言:一步一个脚印才能承接所谓的幸运本文来自专栏:MySQL8.0学习笔记
本文参考视频:MySQL数据库全套教程
欢迎点击支持订阅专栏 ️
文章目录
1 触发器概述
触发器介绍:
- 触发器,就是一种特殊的存储过程。 触发器和存储过程一样是一个能够完成特定功能,存储在数据库服务器上的SQL片段。但是触发器无需调用,当对数据库中的数据执行DML操作时会自动触发这个SQL片段的执行,无需手动调用。
- 在MySQL中,只有执行insert、delete、update操作时才能触发触发器的执行;
- 触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作;
- 使用别名OLD与NEW来引用触发器发生变化的记录内容,这与其他的数据库是相似的。现在触发器还 只支持行级触发,不支持语句级触发。
触发器示意图:
触发器定义在表上,附着在表上。
触发器在定义时,需要指定:
- 什么条件触发?插入、删除、更新?
- 什么时候触发?增删改前或后?
- 触发频率,针对每一行。
2 触发器的基本操作
2.1 创建触发器
1.创建只有一个执行语句的触发器:
create trigger 触发器名 before|after 触发事件
on 表名 for each row
执行语句;
2.创建有多个执行语句的触发器:
create trigger 触发器名 before|after 触发事件
on 表名 for each row
begin
执行语句列表
end;
2.2 触发器操作实例
首先进行数据准备,定义两个表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 $$
CREATE TRIGGER trigger_test02
BEFORE UPDATE
ON user
FOR EACH ROW
BEGIN
INSERT INTO user_logs VALUES (NULL, NOW(), '用户信息被修改');
END $$
DELIMITER ;
UPDATE user SET password = '111111' WHERE uid = 1;
可以看到 user表中的密码被修改,日志表中成功添加了修改信息的记录。
3 NEW与OLD
3.1 为什么需要NEW与OLD?
MySQL中定义了NEW和OLD,用来表示触发器所在表中,触发了触发器哪一行数据,来引用触发器中发生变化的记录内容, 具体见下表:
触发器类型 | 触发器类型NEW与OLD的使用 |
---|---|
INSERT型触发器 | NEW表示将要或者已经新增的数据 |
UPDATE型触发器 | OLD表示修改之前的数据,NEW表示将要或者已经修改后的数据 |
DELETE型触发器 | OLD表示将要或者已经删除的数据 |
使用方法:
NEW.columnName(columnName表示相应数据的某一列名)
何种需求下会使用到NEW和OLD呢?
在上面举例的案例中,我们修改user表中的密码,给user_logs表中添加了修改信息。但是仅仅提示了修改了信息,并没有指明。假如,在信息中需要指明修改前的密码或者修改后的密码,则需要使用到OLD和NEW用于触发器来引用数据!
3.2 NEW与OLD实例
定义触发器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;
4 触发器的其他操作
- 查看触发器:
show triggers;
- 删除触发器:
drop trigger if exists trigger_name;
5 触发器的注意事项
- MySQL中触发器中不能对本表进行insert、update、delete操作,以免递归循环触发;
- 尽量少使用触发器,假设触发器触发每次执行1s,则每次进行对表的修改、更新操作的时候都会额外消耗一定的时间,从而导致对表操作的效率低下;
- 触发器是针对每一行的,对增删改非常频繁的表尽量不要使用触发器,避免额外消耗资源;
- 频繁使用触发器会导致将来维护数据的时候更加麻烦,因为一次更改会有多种行为发生。
写在最后
以上便是本文的全部内容啦,后续内容将会持续免费更新,如果文章对你有所帮助,麻烦动动小手点个赞 + 关注,非常感谢 ️ ️ ️ !
如果有问题,欢迎私信或者评论区!
共勉:“你间歇性的努力和蒙混过日子,都是对之前努力的清零。”
边栏推荐
- All about PDF crack, a complete solution to meet all your PDF needs
- One click deployment of highly available emqx clusters in rainbow
- JS的操作
- Appeler l'interface du moteur de création du service multimédia de jeu Huawei renvoie le Code d'erreur 1002, le message d'erreur: les paramètres sont l'erreur
- 【微信小程序:缓存操作】
- Pvtv2--pyramid vision transformer V2 learning notes
- 2-3 lookup tree
- [IELTS speaking] Anna's oral learning records Part3
- go写一个在一定时间内运行的程序
- Qt Charts使用(重写QChartView,实现一些自定义功能)
猜你喜欢
IP地址的类别
Implement your own dataset using bisenet
One click installation of highly available Nacos clusters in rainbow
Interpreting the practical application of maker thinking and mathematics curriculum
Opencv learning note 5 - gradient calculation / edge detection
调用华为游戏多媒体服务的创建引擎接口返回错误码1002,错误信息:the params is error
Open3D ISS关键点
单元测试报告成功率低
[hard core science popularization] working principle of dynamic loop monitoring system
DeiT学习笔记
随机推荐
Teach you how to select PCB board by hand (II)
Learn how to compile basic components of rainbow from the source code
MES系統,是企業生產的必要選擇
Rainbow 5.7.1 supports docking with multiple public clouds and clusters for abnormal alarms
What is the method of manual wiring in PCB design in 22protel DXP_ Chengdu electromechanical Development Undertaking
Several ways of lambda used in functions in kotlin (higher-order functions)
如何在HarmonyOS应用中集成App Linking服务
idea里使用module项目的一个bug
如何在图片的目标中添加目标的mask
Le système mes est un choix nécessaire pour la production de l'entreprise
POJ - 3616 Milking Time(DP+LIS)
String operation
A method for quickly viewing pod logs under frequent tests (grep awk xargs kuberctl)
Ebpf cilium practice (2) - underlying network observability
Snyk dependency security vulnerability scanning tool
Analyzing the influence of robot science and technology development concept on Social Research
Input of mathematical formula of obsidan
Golang compilation constraint / conditional compilation (/ / +build < tags>)
Calling the creation engine interface of Huawei game multimedia service returns error code 1002, error message: the params is error
Appeler l'interface du moteur de création du service multimédia de jeu Huawei renvoie le Code d'erreur 1002, le message d'erreur: les paramètres sont l'erreur