PL/SQL 触发器以防止插入

Posted

技术标签:

【中文标题】PL/SQL 触发器以防止插入【英文标题】:PL/SQL Trigger to prevent insertion 【发布时间】: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约束来实现。

【问题讨论】:

【参考方案1】:

触发器是执行此操作的错误方法。相反,使用check 约束:

alter table Rent add constraint chk_id_status check (id_status not in (1, 2));

【讨论】:

【参考方案2】:

我认为您应该使用BEFORE INSERT 触发器。 也许使用Raise_Application_Error()。 例如:

CREATE OR REPLACE TRIGGER HelloWorld
BEFORE INSERT ON TableA
FOR EACH ROW
BEGIN
        IF :NEW.id_status IN (1,2) THEN
                Raise_Application_Error (-20100, 'Something to post when raising error.');
        END IF;
END;
/

【讨论】:

你对 Raise_application 的理解是正确的,只是一个旁注,你可以在插入之前或之后触发它。双向工作。 你从哪里得到-20343 @Matthew 这是一个示例错误代码。本文向您展示了更多信息:docs.oracle.com/cloud/latest/db112/LNPLS/errors.htm#LNPLS99960,在“RAISE_APPLICATION_ERROR 程序”部分下。我把它编辑成不那么随机的东西。 :-)

以上是关于PL/SQL 触发器以防止插入的主要内容,如果未能解决你的问题,请参考以下文章

pl/sql 触发器完整性约束问题

PL/SQL 触发器插入下一个值

基于变化表中的值在插入之前触发 PL/SQL 触发器

使用 PL/SQL 在触发器中中止插入/更新操作

更新同一表中的值的 PL/SQL 插入和删除触发器

在使用 Entity Framework 数据库优先在表上插入行之前,如何从 PL/SQL 执行触发器?