当前位置: 首页 > news >正文

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;
 

http://www.xdnf.cn/news/481501.html

相关文章:

  • ubuntu 20.04 更改国内镜像源-阿里源 确保可用
  • 适合学校使用的桌面信息看板,具有倒计时、桌面时钟、课程表、天气预报、自动新闻联播、定时关机、消息通知栏、随机点名等功能。
  • CMU-15445(4)——PROJECT#1-BufferPoolManager-Task#2
  • 【软件工程】符号执行与约束求解缺陷检测方法
  • MySQL性能优化
  • RAG-MCP:基于检索增强生成的大模型工具选择优化框架
  • Cross-Site Scripting(XSS)
  • AT9850B—单北斗导航定位芯片
  • 【leetcode】94. 二叉树的中序遍历
  • 逻辑回归(二分类)
  • Linux的日志管理
  • 青少年ctf平台应急响应-应急响应2
  • 在vue3中使用Cesium的保姆教程
  • 【2025年软考中级】第一章1.5 输入输出技术(外设)
  • 代码随想录第51天|岛屿数量(深搜)、岛屿数量(广搜)、岛屿的最大面积
  • 2025年Ai写PPT工具推荐,这5款Ai工具可以一键生成专业PPT
  • Java—— 方法引用 : :
  • 【第76例】IPD流程实战:华为业务流程架构BPA进化的4个阶段
  • ROS2学习(3)------架构概述
  • 【数据仓库面试题合集①】数据建模高频面试题及解析
  • 平衡智慧在日常生活中的落地实践:构建和谐生活的行动指南
  • MYSQL创建索引的原则
  • 单例模式深度解析:从原理到高阶应用实践
  • 麒麟桌面系统文件保险箱快捷访问指南:让重要文件夹一键直达桌面!
  • [MySQL实战] 主从复制(Replication)搭建教程:实现读写分离与高可用基础
  • 项目QT+ffmpeg+rtsp(一)——Qt的安装和rtsp的测试
  • python的家教课程管理系统
  • spring cloud gateway 源码解析
  • 嵌入式单片机中STM32F1演示寄存器控制方法
  • Linux系统编程——exec族函数