我的编程空间,编程开发者的网络收藏夹
学习永远不晚

【MySQL】数据库进阶之触发器内容详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

【MySQL】数据库进阶之触发器内容详解

💁 个人主页:黄小黄的博客主页
❤️ 支持我:👍 点赞 🌷 收藏 🤘关注
🎏 格言:一步一个脚印才能承接所谓的幸运

本文来自专栏:MySQL8.0学习笔记
本文参考视频:MySQL数据库全套教程
欢迎点击支持订阅专栏 ❤️
在这里插入图片描述



1 触发器概述

🐰 触发器介绍:

  • 触发器,就是一种特殊的存储过程。 触发器和存储过程一样是一个能够完成特定功能,存储在数据库服务器上的SQL片段。但是触发器无需调用,当对数据库中的数据执行DML操作时会自动触发这个SQL片段的执行,无需手动调用。
  • 在MySQL中,只有执行insert、delete、update操作时才能触发触发器的执行;
  • 触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作;
  • 使用别名OLD与NEW来引用触发器发生变化的记录内容,这与其他的数据库是相似的。现在触发器还 只支持行级触发,不支持语句级触发。

🦁 触发器示意图:
在这里插入图片描述
触发器定义在表上,附着在表上。
触发器在定义时,需要指定:

  1. 什么条件触发?插入、删除、更新?
  2. 什么时候触发?增删改前或后?
  3. 触发频率,针对每一行。

2 触发器的基本操作

2.1 创建触发器

1.创建只有一个执行语句的触发器:

create trigger 触发器名 before|after 触发事件on 表名 for each row执行语句;

2.创建有多个执行语句的触发器:

create trigger 触发器名 before|after 触发事件on 表名 for each rowbegin执行语句列表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 ROWBEGIN    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 ROWBEGIN    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 触发器的其他操作

  1. 查看触发器:
show triggers;
  1. 删除触发器:
drop trigger if exists trigger_name;

5 触发器的注意事项

  • MySQL中触发器中不能对本表进行insert、update、delete操作,以免递归循环触发;
  • 尽量少使用触发器,假设触发器触发每次执行1s,则每次进行对表的修改、更新操作的时候都会额外消耗一定的时间,从而导致对表操作的效率低下;
  • 触发器是针对每一行的,对增删改非常频繁的表尽量不要使用触发器,避免额外消耗资源;
  • 频繁使用触发器会导致将来维护数据的时候更加麻烦,因为一次更改会有多种行为发生。

写在最后

🌟以上便是本文的全部内容啦,后续内容将会持续免费更新,如果文章对你有所帮助,麻烦动动小手点个赞 + 关注,非常感谢 ❤️ ❤️ ❤️ !
如果有问题,欢迎私信或者评论区!
在这里插入图片描述

共勉:“你间歇性的努力和蒙混过日子,都是对之前努力的清零。”
在这里插入图片描述

来源地址:https://blog.csdn.net/m0_60353039/article/details/125647356

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

【MySQL】数据库进阶之触发器内容详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

【MySQL】数据库进阶之触发器内容详解

💁 个人主页:黄小黄的博客主页 ❤️ 支持我:👍 点赞 🌷 收藏 🤘关注 🎏 格言:一步一个脚印才能承接所谓的幸运 本文来自专栏:MySQL8.0学习笔记
2023-08-30

详解MySQL数据库之触发器

1 引言本文是对MySQL中触发器的总结,从触发器概念出发,结合实例对创建触发器、使用触发器、删除触发器进行介绍。 2 触发器简介MySQL触发器和存储过程一样,都是嵌入到MySQL的一段程序。触发器是由事件来触发某个操作,这些事件包括IN
2022-05-20

数据库触发器进阶指南:揭秘触发器的强大功能

数据库触发器是一种允许您在数据库操作(如插入、更新或删除)发生时自动执行动作的机制。它提供了增强数据库完整性、实现业务逻辑和提高性能的强大功能。本指南将深入探讨触发器的概念、类型、创建和管理,并通过演示代码揭示触发器的强大功能。
数据库触发器进阶指南:揭秘触发器的强大功能
2024-02-08

MySQL数据库实验之 触发器和存储过程

目录一、实验目的二、实验要求三、实现内容及步骤1、创建一个不带参数的简单存储过程2、创建一个带输入参数的存储过程3、创建一个带输入输出参数的存储过程4、触发器的创建与使用四、实验总结观前提示:本篇内容为mysql数据库实验,代码内容经测试过
2022-06-20

MySQL触发器与数据库复制环境的兼容性

MySQL触发器与数据库复制环境的兼容性是一个需要细致考虑的问题。在深入探讨之前,我们先对MySQL触发器及其在数据库复制环境中的潜在影响有一个基本的了解。MySQL触发器概述MySQL触发器是一种自动化机制,它允许在数据库中定义特定事
MySQL触发器与数据库复制环境的兼容性
2024-09-26

详解JavaEE 使用 Redis 数据库进行内容缓存和高访问负载

NoSQL(Not Only SQL),泛指非关系型数据库,是为了处理高并发读写、海量数据的高效率存储和访问、高扩展性和高可用性而产生的。 分类 相关产品 典型应用 数据模型 优
2023-05-31

javascript在Marquee内的内容移动至Marquee显示范围之外时触发此事件使用什么函数,详细讲解

当鼠标指针移出Marquee元素时,触发onmouseout事件,可执行特定行为。onmouseout事件语法为,其中myFunction()为回调函数。常用做法是利用onmouseout事件在Marquee内容移动至显示范围之外时采取措施,如停止滚动、隐藏Marquee或更改滚动方向。示例中通过onmouseout事件停止Marquee滚动:。当鼠标移出Marquee,将执行回调函数this.stop(),调用Marquee元素的stop()方法,停止滚动。
javascript在Marquee内的内容移动至Marquee显示范围之外时触发此事件使用什么函数,详细讲解
2024-04-02

javascript当对象被鼠标拖动的对象进入其容器范围内时触发此事件使用什么函数,详细讲解

当用户将对象拖入容器时,可使用JavaScript中的dragenter事件处理程序触发事件。此事件处理程序接收一个事件对象,其中包含有关拖放的数据、目标元素和光标位置的详细信息。可使用此信息执行自定义行为,例如将文件添加到容器或更新元素的样式。在使用dragenter事件处理程序时,遵循阻止默认行为、检查数据类型和自定义事件处理程序代码的最佳实践至关重要。
javascript当对象被鼠标拖动的对象进入其容器范围内时触发此事件使用什么函数,详细讲解
2024-04-02

javascript当对象被鼠标拖动的对象离开其容器范围内时触发此事件使用什么函数,详细讲解

当对象被鼠标拖动离开容器时触发的JavaScript函数是dragleave。此事件在以下条件下触发:对象完全离开容器边界对象进入另一个元素边界dragleave事件处理程序负责更新视觉提示、停止接收数据传输事件并恢复元素的默认状态。最佳实践包括使用容器元素作为事件监听器、防止默认操作并清除视觉提示。
javascript当对象被鼠标拖动的对象离开其容器范围内时触发此事件使用什么函数,详细讲解
2024-04-02

javascript当某被拖动的对象在另一对象容器范围内拖动时触发此事件使用什么函数,详细讲解

dragenter和dragleave事件在JavaScript中用于管理拖放操作。当可拖动对象进入或离开另一个对象的容器范围时,它们会触发。dragenter事件用于在对象进入容器时执行操作,例如突出显示容器。dragleave事件用于在对象离开容器时撤销先前操作。最佳实践包括使用事件委托、防止重复触发、提供视觉提示和处理数据传输。这些事件有助于提供直观的用户体验并提高拖放操作的可控性。
javascript当某被拖动的对象在另一对象容器范围内拖动时触发此事件使用什么函数,详细讲解
2024-04-02

编程热搜

目录