MySQL触发器基本结构

1、修改分隔符符号

delimiter $$
可以修改成$$ //都行
2、创建触发器函数名称

create trigger 函数名
3、什么样的操作触发,操作那个表

after:....之后触发

befor:....之前触发

insert:插入被触发

update:修改被触发

delete:删除被触发

on 表名

实例:在users表被添加信息后触发

after insert on users
4、for each row 声明每次触发都被执行

5、开始触发器代码

begin

6、触发器触发后执行代码块
7、结束触发器

end ;
8、修改分隔符

delimiter ;

sql 复制代码
INSERT into `user`
(username,`password`)
values('貂2蝉6166','123');
# 使用;就代表会停止sql
# 添加的触发器
# 1、各种唯一索引限制导致报错
# 2、de limit er 单词错误
# 3、结束的时候先写;结束在将$$更换成;
delimiter $$ # 分隔符
CREATE TRIGGER after_inster_user123 --创建触发器的名称
after insert on `user` --用户表执行插入操作之后被出发的触发器
for each row -- 每行数据都要进行触发
BEGIN
 -- 触发器的语句
 --signal sqlstate '45000'代表错误,会停止操作,包含插入语句也会取消commit操作
 signal sqlstate '45000' set message_text='我们认为的停止了数据commit';
 end;
 $$
 delimiter ; #结束$$的有效性更换成;
相关推荐
奔跑的小十一2 小时前
JDBC接口开发指南
java·数据库
熊大如如2 小时前
PostgreSQL 创建只读账户
数据库·postgresql
Zzzone6833 小时前
MySQL故障排查与生产环境优化
mysql
尽兴-3 小时前
达梦数据库CASE WHEN条件
数据库·oracle·达梦
遗忘妳4 小时前
PostgreSQL初体验
数据库·postgresql
苹果醋34 小时前
AI大模型竞赛升温:百度发布文心大模型4.5和X1
java·运维·spring boot·mysql·nginx
皮皮林5514 小时前
面试官问:你写代码会复用公共 SQL 么?
mysql
YuTaoShao5 小时前
Java八股文——Spring「Spring 篇」
java·数据库·spring
一线大码6 小时前
SpringBoot 和 MySQL 的事务隔离级别关系
spring boot·后端·mysql
新知图书6 小时前
扣子数据库实战案例:搭建AI登记助手
数据库·智能体·扣子