mysql 触发器

创建触发器

  • 这个需要使用 mysql 触发器,用户删除数据时检测删除的是不是我们设置禁止删除的数据,如果是,则报错,禁止用户删除
mysql 复制代码
DELIMITER $$
# prevent_delete_row 触发器名称
CREATE TRIGGER prevent_delete_row 
# kaili_erp.employee 数据库和表名
BEFORE DELETE ON kaili_erp.employee 
FOR EACH ROW 
BEGIN
    DECLARE msg VARCHAR(255);
    # OLD.字段名 = 值
    IF OLD.uid = '10000' THEN
		# 错误提示消息
        SET msg = 'Cannot delete this row!';
        SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = msg;
    END IF;
END;
$$
DELIMITER ;

如果要创建禁止修改的触发器,仅需把 BEFORE DELETE ON 换成 BEFORE UPDATE ON 就可以了

删除触发器

  • 查看已有触发器
mysql 复制代码
SHOW TRIGGERS;
  • 删除触发器
mysql 复制代码
# `trigger_name` 是要删除的触发器名称
# `IF EXISTS` 可以加上,以避免尝试删除不存在的触发器时出现错误
DROP TRIGGER [IF EXISTS] trigger_name;
相关推荐
武帝为此2 分钟前
【软件开发日志介绍】
java·前端·数据库
likerhood4 分钟前
Java 反射与注解的详细讲解
java·开发语言·数据库
todoitbo7 分钟前
时序数据库选型指南(实战版):做一轮可落地评估
数据库·时序数据库
数智化精益手记局14 分钟前
设备管理与维护包括哪些内容?详解设备管理与维护的流程
网络·数据库·人工智能
YL2004042616 分钟前
MySQL-基础篇-MySQL概述
数据库·mysql
毋语天20 分钟前
Docker 环境下 Milvus 向量数据库的稳定部署与常见问题
数据库·docker·milvus
IMPYLH21 分钟前
Linux 的 uname 命令
linux·运维·服务器·数据库·bash
Raina测试21 分钟前
基于Skills的接口自动化测试方案|新增 MySQL 断言,实现接口 + 数据库双校验
软件测试·数据库·接口自动化测试·测试工程师·skill·ai测试
且去填词23 分钟前
Go并发模式进阶:从Worker Pool到可取消任务调度器
数据库·oracle·golang
smileNicky26 分钟前
面试高频:MySQL Binlog 的三种模式
mysql·面试·职场和发展