💁 个人主页:黄小黄的博客主页
❤️ 支持我:👍 点赞 🌷 收藏 🤘关注
🎏 格言:一步一个脚印才能承接所谓的幸运本文来自专栏:MySQL8.0学习笔记
本文参考视频:MySQL数据库全套教程
欢迎点击支持订阅专栏 ❤️
文章目录
1 触发器概述
🐰 触发器介绍:
- 触发器,就是一种特殊的存储过程。 触发器和存储过程一样是一个能够完成特定功能,存储在数据库服务器上的SQL片段。但是触发器无需调用,当对数据库中的数据执行DML操作时会自动触发这个SQL片段的执行,无需手动调用。
- 在MySQL中,只有执行insert、delete、update操作时才能触发触发器的执行;
- 触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作;
- 使用别名OLD与NEW来引用触发器发生变化的记录内容,这与其他的数据库是相似的。现在触发器还 只支持行级触发,不支持语句级触发。
🦁 触发器示意图:
触发器定义在表上,附着在表上。
触发器在定义时,需要指定:
- 什么条件触发?插入、删除、更新?
- 什么时候触发?增删改前或后?
- 触发频率,针对每一行。
2 触发器的基本操作
2.1 创建触发器
1.创建只有一个执行语句的触发器:
createtrigger 触发器名 before|after 触发事件
on 表名 for each row
执行语句;
2.创建有多个执行语句的触发器:
createtrigger 触发器名 before|after 触发事件
on 表名 for each rowbegin
执行语句列表
end;
2.2 触发器操作实例
首先进行数据准备,定义两个表user与user_logs,分别记录用户注册信息和用户操作日志。希望当user发生变化时,user_logs自动发生变化(通过触发器实现)。 数据准备相关代码如下:
CREATEDATABASEIFNOTEXISTS mydatabase_tigger;USE mydatabase_tigger;-- 用户表创建CREATETABLEuser(
uid INTPRIMARYKEY,
username VARCHAR(50)NOTNULL,
password VARCHAR(50)NOTNULL);-- 用户信息操作日志表CREATETABLE user_logs(
id INTPRIMARYKEYAUTO_INCREMENT,timeTIMESTAMP,
log_text VARCHAR(255));
- 若希望给user表添加信息时,user_logs表自动添加一行数据,在下面代码中定义了一个触发器trigger_test01来实现需求,相关代码与结果如下:
CREATETRIGGER trigger_test01
AFTERINSERTONuserFOR EACH ROWINSERTINTO user_logs
VALUES(NULL,NOW(),'新用户添加');INSERTINTOuserVALUES(1,'nezuko','123456');
- 当user表数据被修改时,自动在user_logs添加日志记录。,在下面代码中定义了一个触发器trigger_test02来实现需求,相关代码与结果如下:
DELIMITER $$
CREATETRIGGER trigger_test02
BEFORE UPDATEONuserFOR EACH ROWBEGININSERTINTO user_logs VALUES(NULL,NOW(),'用户信息被修改');END $$
DELIMITER;UPDATEuserSET 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 $$
CREATETRIGGER trigger_test03
BEFORE UPDATEONuserFOR EACH ROWBEGININSERTINTO user_logs VALUES(NULL,NOW(), CONCAT('用户信息被修改,修改前的密码为', OLD.password,',修改后为', NEW.password));END $$
DELIMITER;UPDATEuserSET password ='99999999'WHERE uid =1;
如果希望删除触发器,则可以使用下面的语句: 删除到目前为止创建的三个触发器。
DROPTRIGGERIFEXISTS trigger_test01;DROPTRIGGERIFEXISTS trigger_test02;DROPTRIGGERIFEXISTS trigger_test03;
4 触发器的其他操作
- 查看触发器:
show triggers;
- 删除触发器:
droptriggerifexists trigger_name;
5 触发器的注意事项
- MySQL中触发器中不能对本表进行insert、update、delete操作,以免递归循环触发;
- 尽量少使用触发器,假设触发器触发每次执行1s,则每次进行对表的修改、更新操作的时候都会额外消耗一定的时间,从而导致对表操作的效率低下;
- 触发器是针对每一行的,对增删改非常频繁的表尽量不要使用触发器,避免额外消耗资源;
- 频繁使用触发器会导致将来维护数据的时候更加麻烦,因为一次更改会有多种行为发生。
写在最后
🌟以上便是本文的全部内容啦,后续内容将会持续免费更新,如果文章对你有所帮助,麻烦动动小手点个赞 + 关注,非常感谢 ❤️ ❤️ ❤️ !
如果有问题,欢迎私信或者评论区!
共勉:“你间歇性的努力和蒙混过日子,都是对之前努力的清零。”
版权归原作者 小黄小黄不再迷茫 所有, 如有侵权,请联系我们删除。