文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-08-30 11:45

关注

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

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



🐰 触发器介绍:

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

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

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));
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');

在这里插入图片描述
在这里插入图片描述

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.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;

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


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

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

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

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯