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;
相关推荐
小吴编程之路5 小时前
MySQL 索引核心特性深度解析:从底层原理到实操应用
数据库·mysql
~莫子5 小时前
MySQL集群技术
数据库·mysql
凤山老林6 小时前
SpringBoot 使用 H2 文本数据库构建轻量级应用
java·数据库·spring boot·后端
就不掉头发6 小时前
Linux与数据库进阶
数据库
与衫6 小时前
Gudu SQL Omni 技术深度解析
数据库·sql
咖啡の猫6 小时前
Redis桌面客户端
数据库·redis·缓存
oradh6 小时前
Oracle 11g数据库软件和数据库静默安装
数据库·oracle
what丶k6 小时前
如何保证 Redis 与 MySQL 数据一致性?后端必备实践指南
数据库·redis·mysql
_半夏曲7 小时前
PostgreSQL 13、14、15 区别
数据库·postgresql
把你毕设抢过来7 小时前
基于Spring Boot的社区智慧养老监护管理平台(源码+文档)
数据库·spring boot·后端