How to write a trigger to abort delete in MYSQL?(如何编写触发器以在 MYSQL 中中止删除?)
问题描述
我读了这个文章 但它似乎不适用于删除.尝试创建触发器时出现此错误:
<块引用>在服务器中执行SQL脚本
错误:错误 1363:DELETE 触发器上没有新行
CREATE TRIGGER DeviceCatalog_PreventDeletion在 DeviceCatalog 上删除之前每行开始DECLARE 虚拟 INT;如果 old.id = 1 或 old.id =2 THENSELECT * FROM DeviceCatalog WHERE DeviceCatalog.id=NEW.id;万一;结尾;<块引用>
SQL 脚本执行完成:语句:4 条成功,1 条失败
试试这个 -
DELIMITER $$创建触发器触发器1删除前ON 表 1每行开始IF OLD.id = 1 THEN -- 尝试删除此记录时中止CALL cannot_delete_error;-- 引发错误以防止从表中删除万一;结尾$$分隔符;I read this article but it seems not work for delete. I got this error when tried to create a trigger:
Executing SQL script in server
ERROR: Error 1363: There is no NEW row in on DELETE trigger
CREATE TRIGGER DeviceCatalog_PreventDeletion
BEFORE DELETE on DeviceCatalog
FOR EACH ROW
BEGIN
DECLARE dummy INT;
IF old.id = 1 or old.id =2 THEN
SELECT * FROM DeviceCatalog WHERE DeviceCatalog.id=NEW.id;
END IF;
END;
SQL script execution finished: statements: 4 succeeded, 1 failed
Try something like this -
DELIMITER $$
CREATE TRIGGER trigger1
BEFORE DELETE
ON table1
FOR EACH ROW
BEGIN
IF OLD.id = 1 THEN -- Abort when trying to remove this record
CALL cannot_delete_error; -- raise an error to prevent deleting from the table
END IF;
END
$$
DELIMITER ;
这篇关于如何编写触发器以在 MYSQL 中中止删除?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何编写触发器以在 MYSQL 中中止删除?
基础教程推荐
- SQL Server 实例在登录协商期间返回无效或不受支持的协议版本 2021-01-01
- SQL:使用来自具有相同列名的两个表中的数据... 2021-01-01
- 是否可以执行按位分组功能? 2021-01-01
- 将 SQL Server DateTime 列迁移到 DateTimeOffset 2021-01-01
- SQL 效率:WHERE IN 子查询 vs. JOIN 然后 GROUP 2021-01-01
- 无法解决整理冲突 2021-01-01
- 需要 MySQL 5.1 中的抽象触发器来更新审计日志 2021-01-01
- 如何使用 mysql.connector 禁用查询缓存 2022-01-01
- 在 SQL 中连接多个表 2021-01-01
- SSMS 中的权限问题:“对象 'extended_properties'、数据库 'mssqlsystem_resource'、... 错误 229)上的 SELECT 权限被拒绝" 2022-01-01
