Mysql中触发器的使用示例

场景

触发器

触发器(Trigger)是一个特殊的存储过程,不同的是执行存储过程要使用 CALL 语句来调用,而触发器的执行不需要使用 CALL 语旬来调用,

也不需要手工启动,只要一个预定义的事件发生就会被MySQL自动调用。

例如,当对一个数据表进行插入、更新或删除等操作时可以激活触发器并执行触发器。

触发程序经常用于加强数据的完整性约束和业务规则等。

触发程序类似于约束,但比约束更灵活,具有更精细、更强大的数据控制能力。

创建触发器

语法格式

复制代码
CREATE TRIGGER trigger_name trigger_time trigger_event

ON tbl_name FOR EACH ROW trigger_stmt

trigger_name:触发器名称

trigger_time:标识触发时机,可以指定为before或after

trigger_event:标识触发事件,包括INSERT、UPDATE、DELETE

tbl_name:标识建立触发器的表名

trigger_stmt:触发器程序体。

触发器程序可以使用BEGIN和END作为开始和结束,中间包含多条语句

创建一个名为in_newstu的触发器,触发的条件是向数据表test_student中插入数据之前对新插入的id进行求和计算。

复制代码
CREATE TRIGGER in_newstu BEFORE INSERT ON test_student
FOR EACH ROW SET @ss= NEW.sid+1;

设置变量的初始值为0

复制代码
SET @ss= 0;

插入数据,启动触发器

复制代码
INSERT INTO test_student VALUES (6, '张三', NULL, 13, 101);

查询变量

复制代码
SELECT @ss;

创建一个触发器,当插入的sid等于7时将姓名设为"霸道"

复制代码
CREATE TRIGGER name_student
BEFORE INSERT
ON test_student
FOR EACH ROW
BEGIN
IF new.sid =7 THEN
SET new.sname ='霸道';
END IF;
END

插入数据并验证

复制代码
INSERT INTO test_student VALUES (7, '张1', NULL, 13, 101);

SELECT * FROM test_student WHERE sid = 7;

查看触发器

复制代码
SHOW TRIGGERS;

还可以通过查看系统表查看触发器

复制代码
SELECT * FROM information_schema.TRIGGERS WHERE TRIGGER_NAME = 'name_student';

删除触发器

复制代码
DROP TRIGGER name_student;
相关推荐
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横3 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二3 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab3 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐3 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
云技纵横4 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神4 天前
三、用户与权限管理
数据库·mysql
摇滚侠5 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql