【发布时间】:2017-05-30 14:32:23
【问题描述】:
我需要在 PL/SQL 中编写触发器。我希望在条件为真时阻止插入。
CREATE OR REPLACE TRIGGER SafeRent AFTER INSERT ON Rent
FOR EACH ROW
DECLARE
BEGIN
IF :NEW.id_status IN (1,2) THEN
DELETE FROM Rent WHERE id_rent = :NEW.id_rent;
END IF;
END;
代码探索:如果 id_status 等于 1 或 2,我希望不进行插入。
这是我写的触发器。如果条件为真,它会在插入后删除(我想是的,我没有测试过)记录。
在插入之前有什么办法可以防止吗?
我正在考虑在 'BEFORE INSERT' 类型触发器中出现异常,这是一个好的解决方案吗?
PS:一定是触发器,我知道可以作为Check约束来实现。
【问题讨论】: