使用mysql触发器的方法
发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,这篇文章主要讲解了使用mysql触发器的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。什么是触发器:触发器用来在某些操作之后,"自动"执行一些操作。(比如插入了新的学
千家信息网最后更新 2024年11月23日使用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安全错误
数据库的锁怎样保障安全
金山区上门软件开发代理品牌
服务器管理口怎么装系统
国内外在网络技术上的差距
服务器8080
哈尔滨冠科网络技术怎么样
多节点服务器的通信方式
access数据库循环体
青岛星润和网络技术有限公司
数据库集群停止命令
集团网络安全意识形态隐患
关于网络安全的书法作品教程
服务器四个虚拟机的系统一样吗
2016 年国家网络安全
香蜜湖java软件开发
第五人格全球服务器地图
model要和数据库结构吗
连云港工程软件开发用途
网络安全技术装备
服务器温度 多少
软件开发技术发展趋势
未来网络技术学习
徐州嘿逗科技互联网推广方案
一台服务器能发布两个ftp吗
数据库恢复测试
统计局计算机网络安全制度
网站指向数据库
dbms在数据库中起什么用
网络安全社区宣传
我的世界竹龙服务器ip
数据库列名的规定