?? 个人主页:黄小黄的博客主页
支持我:?? 点赞 ?? 收藏 ??关注
?? 格言:一步一个脚印才能承接所谓的幸运本文来自专栏:MySQL8.0学习笔记
本文参考视频:MySQL数据库全套教程
欢迎点击支持订阅专栏
文章目录
1 触发器概述
?? 触发器介绍:
- 触发器,就是一种特殊的存储过程。 触发器和存储过程一样是一个能够完成特定功能,存储在数据库服务器上的SQL片段。但是触发器无需调用,当对数据库中的数据执行DML操作时会自动触发这个SQL片段的执行,无需手动调用。
- 在MySQL中,只有执行insert、delete、update操作时才能触发触发器的执行;
- 触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作;
- 使用别名OLD与NEW来引用触发器发生变化的记录内容,这与其他的数据库是相似的。现在触发器还 只支持行级触发,不支持语句级触发。
?? 触发器示意图:
触发器定义在表上,附着在表上。
触发器在定义时,需要指定:
- 什么条件触发?插入、删除、更新?
- 什么时候触发?增删改前或后?
- 触发频率,针对每一行。
2 触发器的基本操作
2.1 创建触发器
1.创建只有一个执行语句的触发器:
create trigger 触发器名 before|after 触发事件
on 表名 for each row
执行语句;
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(),