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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 文章目录1 触发器概述2 触发器的基本操作2.1 创建触发器2.2 触发器操作实例3 NEW与OLD3.1 为什么需要NEW与OLD?3.2 NEW与OLD实例4 触发器的其他操作5 触发器的注意事项

1 触发器概述

🐰 触发器介绍:


触发器,就是一种特殊的存储过程。 触发器和存储过程一样是一个能够完成特定功能,存储在数据库服务器上的SQL片段。但是触发器无需调用,当对数据库中的数据执行DML操作时会自动触发这个SQL片段的执行,无需手动调用。

在MySQL中,只有执行insert、delete、update操作时才能触发触发器的执行;

触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作;

使用别名OLD与NEW来引用触发器发生变化的记录内容,这与其他的数据库是相似的。现在触发器还 只支持行级触发,不支持语句级触发。

🦁 触发器示意图:


触发器定义在表上,附着在表上。

触发器在定义时,需要指定:


什么条件触发?插入、删除、更新?

什么时候触发?增删改前或后?

触发频率,针对每一行。

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;

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

删除触发器:

drop trigger if exists trigger_name;
1

5 触发器的注意事项

MySQL中触发器中不能对本表进行insert、update、delete操作,以免递归循环触发;

尽量少使用触发器,假设触发器触发每次执行1s,则每次进行对表的修改、更新操作的时候都会额外消耗一定的时间,从而导致对表操作的效率低下;

触发器是针对每一行的,对增删改非常频繁的表尽量不要使用触发器,避免额外消耗资源;

频繁使用触发器会导致将来维护数据的时候更加麻烦,因为一次更改会有多种行为发生。


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5天前
|
缓存 算法 关系型数据库
Mysql(3)—数据库相关概念及工作原理
数据库是一个以某种有组织的方式存储的数据集合。它通常包括一个或多个不同的主题领域或用途的数据表。
23 5
Mysql(3)—数据库相关概念及工作原理
|
4天前
|
关系型数据库 MySQL 数据库
MySQL数据库基础(数据库操作,常用数据类型,表的操作)
MySQL数据库基础(数据库操作,常用数据类型,表的操作)
22 5
|
5天前
|
SQL JSON 关系型数据库
MySQL是一个广泛使用的开源关系型数据库管理系统,它有许多不同的版本
【10月更文挑战第3天】MySQL是一个广泛使用的开源关系型数据库管理系统,它有许多不同的版本
33 5
|
3天前
|
关系型数据库 MySQL 数据库
mysql关系型数据库的学习
mysql关系型数据库的学习
8 0
|
6天前
|
数据可视化 关系型数据库 MySQL
【IDEA】配置mysql环境并创建mysql数据库
【IDEA】配置mysql环境并创建mysql数据库
30 0
|
1月前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
1月前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
265 11
|
9天前
|
存储 关系型数据库 MySQL
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB区别,适用场景
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB——特点、性能、扩展性、安全性、适用场景比较
|
8天前
|
SQL 关系型数据库 MySQL
|
28天前
|
存储 SQL 关系型数据库
MySQL的安装&数据库的简单操作
本文介绍了数据库的基本概念及MySQL的安装配置。首先解释了数据库、数据库管理系统和SQL的概念,接着详细描述了MySQL的安装步骤及其全局配置文件my.ini的调整方法。文章还介绍了如何启动MySQL服务,包括配置环境变量和使用命令行的方法。最后,详细说明了数据库的各种操作,如创建、选择和删除数据库的SQL语句,并提供了实际操作示例。
67 13
MySQL的安装&数据库的简单操作