• 【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
    执行语句;
    
    • 1
    • 2
    • 3

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

    create trigger 触发器名 before|after 触发事件
    on 表名 for each row
    begin
    	执行语句列表
    end;
    
    • 1
    • 2
    • 3
    • 4
    • 5

    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)
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 若希望给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表中的密码被修改,日志表中成功添加了修改信息的记录。


    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;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述
    在这里插入图片描述
    如果希望删除触发器,则可以使用下面的语句: 删除到目前为止创建的三个触发器。

    DROP TRIGGER IF EXISTS trigger_test01;
    DROP TRIGGER IF EXISTS trigger_test02;
    DROP TRIGGER IF EXISTS trigger_test03;
    
    • 1
    • 2
    • 3

    4 触发器的其他操作

    1. 查看触发器:

      show triggers;

    2. 删除触发器:

      drop trigger if exists trigger_name;


    5 触发器的注意事项

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

    写在最后

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

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

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    人工智能知识全面讲解:感知机原理
    bash while循环和until循环
    Sentinel授权规则和规则持久化
    MySQL-运维篇 初识
    vue路由传参刷新丢失
    【数据结构与算法】---OJ手撕链表题
    OpenCV中的HoughLines函数和HoughLinesP函数到底有什么区别?
    C/C++空格分开输出 2019年12月电子学会青少年软件编程(C/C++)等级考试一级真题答案解析
    lazada-商品详情
    从应用访问Pod元数据-DownwardApi的应用
  • 原文地址:https://blog.csdn.net/m0_67402235/article/details/126080622