使用mysql触发器的方法
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,这篇文章主要讲解了使用mysql触发器的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。什么是触发器:触发器用来在某些操作之后,"自动"执行一些操作。(比如插入了新的学
千家信息网最后更新 2025年01月22日使用mysql触发器的方法
这篇文章主要讲解了使用mysql触发器的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
什么是触发器:
- 触发器用来在某些操作之后,"自动"执行一些操作。(比如插入了新的学生信息,那么在班级表中应该修改学生数)。
- 当insert delete update设置触发器之后,执行insert delete update操作就会自动触发设置的内容。
- 一张表最大能有6个触发器(3*2,三种操作*两种时间(before|after))。
创建触发器:
- 语法:create trigger 触发器名 before|after 事件 on 表名 for each row 触发器语句;
- 触发器名建议为trigger_xxx,这样便于区分,触发器名不能重复。
- before|after 代表触发器语句执行时间,如果是before,就是在insert delete update操作之前执行触发器语句;after就是之后。
- 事件就是insert delete update操作中的一个。
- for each row 是代表任何记录执行对应操作都会触发器。
- 触发器语句就是触发器触发时要执行的语句。
- 比如:下面是一个当插入新用户时,在用户创建时间表中插入一条新数据,是当前时间。
create trigger trigger_addUserTime before insert on user_info for each row insert into usercreatetime(create_time) values(now());
create table user_info(id int primary key auto_increment,username varchar(20) not null,password varchar(20) not null)create table usercreatetime(id int primary key auto_increment,create_time datetime);create trigger trigger_addUserTime before insert on user_info for each row insert into usercreatetime(create_time) values(now());insert into user_info(username,password) values("admin","admin888");select * from usercreatetime;
多条触发器语句情况:
- 需要将多条语句包裹在begin end中
- 比如:
- 但要注意,上述情况适用于非命令行模式(上面是在navicat中运行的),如果要命令行中执行需要修改命令结束符(mysql命令默认以";"为语句结束符,如果我们不修改,那么键入一条触发器语句并以;结束时就会认为语句已经结束,然后就会因为语句不完整报错)【delimiter 自定义符号-- 临时修改语句结束符为指定符号】。
- 【将结束符定义成$$就可以在触发器语句中使用;结束】
delimiter $$ -- 一般定义成$$create trigger 触发器名 before|after 事件 on 表名 for each row begin 语句;语句;end $$delimiter ;-- 示例delimiter $$ -- 一般定义成$$create trigger trigger_addUserTime23 before insert on user_info for each row begin insert into usercreatetime(create_time) values(now());insert into usercreatetime(create_time) values(now());end $$delimiter ;
- 【将结束符定义成$$就可以在触发器语句中使用;结束】
查看触发器:
- 使用show triggers\G 查看所有触发器
- 在数据库information_schema中通过查看触发器表,来查看触发器:使用select * from triggers\G;【当然可以以触发器名作为where条件查找数据】
- 查看触发器创建语句:show create trigger 触发器名\G;
删除触发器:
- 使用drop trigger 触发器名;来删除触发器
触发器的新旧记录引用:
- 对于某些情况有时候可能需要引用一下之前的数据,比如增加学生数需要知道之前的学生数
- new是新插入的数据,old是原来的数据【插入的时候没有旧数据,删除没有新数据,更新既有旧又有新。(这里指的是事件类型)】
- 使用odl\new.字段名来引用数据。(注意引用的是触发触发器(事件)的语句的数据)
- 下面是一个例子:(当插入学生记录时,通过new.name获取新插入的学生的名字,然后将new.name插入到另一个表中)
create table student(id int primary key auto_increment,name varchar(15) not null,gender varchar(15) not null);create table stu_info(name varchar(15) not null);create trigger addCount before insert on student for each row insert into stu_info values(new.name);insert into student(name,gender) values("lilei","male");select * from stu_info;
看完上述内容,是不是对使用mysql触发器的方法有进一步的了解,如果还想学习更多内容,欢迎关注行业资讯频道。
触发器
语句
数据
学生
事件
内容
命令
就是
时间
结束符
情况
方法
代表
多条
用户
符号
学习
最大
例子
兴趣
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
cad软件开发 上海
会计转软件开发
常州交友软件开发
《数据库原理》在线作业
什么是数字电视双向网络技术
视易利云服务器
服务器真的安全吗
java二维数据库表结构设计
服务器如何接收数据
mc服务器服主和管理员
怎么介绍网络安全
明日方舟模组数据库块是什么
薛城区网络安全保障中心事业单位
mac使用数据库
软件开发转正定级
云数据库如何管理
网络安全教育专项行动
口袋妖怪复刻九游数据库
网络安全责任承诺书6
黄骅服务器托管
ETH矿机服务器配置
广电网络安全攻防演练大赛
阿联酋政府网络安全博会
组建软件开发成本
客户端 云服务器
数据库表导入到另一个库
云数据库如何管理
网络安全标准2021网盘
网页怎么把图片存进数据库
手机网络安全证书怎么删除