MySQL的触发器

本章了解一下即可,并不是很难,大家加油!!!

触发器实际上是多表关联的一个操作,无需调用,是一个自动的过程,当对数据库表中的数据执行DML操作时自动触发这个SQL片段的执行,无需手动调用

只有执行insert、delete、update操作时才能触发触发器的执行

只支持行级触发

一、基本操作

只有一个执行语句

有多个执行语句

一次添加多行,触发器也会触发多次

二、new和old

就是用来记录信息变化的,可以记录信息变化之前是什么样子,变化之后是什么样子

触发器如果没有删除,就可能存在一条语句触发好几个触发器

三、其他操作

展示触发器

删除触发器

四、注意事项

尽量让他的逻辑简单一点,不然很多个触发器,很消耗资源

五、完整代码

-- 数据准备

create database if not exists mydb10_trigger;

use mydb10_trigger;

-- 用户表

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.当user表添加一行数据,则会自动在user_logs添加日志记录

-- 定义触发器

create trigger trigger_test1 after insert

on user for each row

insert into user_logs values(NULL,now(),'有新用户添加');

-- now()函数返回当前时间

-- 在user表添加数据,让触发器自动执行

insert into user values(2,'ikun','123456');

-- 2.当user表数据被修改时,则会自动在user_logs添加日志记录

delimiter $$

create trigger trigger_test2 before update

on user for each row

begin

insert into user_logs values(NULL,now(),'有用户信息被修改了');

end $$

delimiter ;

-- 在user表中修改数据,让触发器自动执行

update user set password = '8888' where uid = 1;

-- new和old

-- insert 类型的触发器

-- new

create trigger trigger_test3 after insert

on user for each row

insert into user_logs values(NULL,now(),concat('有新用户添加,信息为:',new.uid,new.username,new.password));

insert into user values(4,'赵六','123456');

-- update类型的触发器

-- old

create trigger trigger_test4 after update

on user for each row

insert into user_logs values(NULL,now(),concat('有新用户信息修改,信息修改之前为:',old.uid,old.username,old.password));

update user set password = '99999' where uid = 4;

-- new

create trigger trigger_test5 after update

on user for each row

insert into user_logs values(NULL,now(),concat_ws(',','有新用户信息修改,信息修改之后为:',new.uid,new.username,new.password));

update user set password = '000' where uid = 4;

-- 删除触发器

drop trigger if exists trigger_test1;

-- delete类型的触发器

-- old

create trigger trigger_test6 after delete

on user for each row

insert into user_logs values(NULL,now(),concat_ws(',','有用户被删除,被删除用户信息为:',old.uid,old.username,old.password));

delete from user where uid = 4;

show triggers;

drop trigger if exists trigger_test1;

相关推荐
@LetsTGBot搜索引擎机器人40 分钟前
2025 Telegram 最新免费社工库机器人(LetsTG可[特殊字符])搭建指南(含 Python 脚本)
数据库·搜索引擎·机器人·开源·全文检索·facebook·twitter
计算机毕设VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue动物园管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
冉冰学姐1 小时前
SSM校园排球联赛管理系统y513u(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架应用·开题报告、
Tony Bai2 小时前
【分布式系统】03 复制(上):“权威中心”的秩序 —— 主从架构、一致性与权衡
大数据·数据库·分布式·架构
wb043072013 小时前
SQL工坊不只是一个ORM框架
数据库·sql
至善迎风3 小时前
Redis完全指南:从诞生到实战
数据库·redis·缓存
QQ_4376643145 小时前
Redis协议与异步方式
数据库·redis·bootstrap
纪莫5 小时前
技术面:MySQL篇(InnoDB事务执行过程、事务隔离级别、事务并发异常)
数据库·java面试⑧股
Nerd Nirvana5 小时前
数据库模型全景:从原理到实践的系统性指南
数据库·oracle·电力行业
SelectDB5 小时前
从 Greenplum 到 Doris:集群缩减 2/3、年省数百万,度小满构建超大规模数据分析平台经验
数据库·数据分析·apache