精深知识:Oracle触发器的分类探寻(oracle触发器类型)


Oracle触发器可以用来阻止不太正确的数据库操作,并在发生某些更新行为时自动执行自定义动作。它们占据了数据库开发和管理的重要角色,但是由于存在各种触发器类型,一般用户很难选择一个正确的触发器来应用于自己的项目当中。为此,我们探讨一下Oracle触发器的分类,以便更好地理解和应用。

我们可以将Oracle触发器分为三忢类,分别是before/after触发器、row-level触发器和statement-level触发器。

Before/ After触发器,又称激发子,指的是在执行表中进行DML操作(如插入、更新、删除)前/后会被触发执行的代码。在激发子中,可以在它们被触发前获取“实际”值,以及在它们被触发后使用“期望”值。下面是一个简单的before after触发器的例子:

CREATE OR REPLACE TRIGGER trg_bef

BEFORE

INSERT OR UPDATE OR DELETE ON tab1

REFERENCING NEW AS new_rec OLD AS old_rec

FOR EACH ROW

BEGIN

IF :new_rec.col1 > :old_rec.col1 THEN

:new_rec.col2 := :old_rec.col2;

END IF;

END;

/

Row-Level触发器指的是在更新时会检查每一行的发生,根据检查的结果执行触发动作。Row-Level触发器比Before/After触发器更为灵活,可以实现更高级的触发动作。下面是一个简单的Row-Level触发器的例子:

CREATE OR REPLACE TRIGGER trg_row

AFTER

INSERT OR UPDATE OR DELETE ON tab1

FOR EACH ROW

BEGIN

IF :new.col1 = ‘SomeValue’ THEN

INSERT INTO tab2 VALUES (:new.col1, :new.col2);

END IF;

END;

/

Statement-Level触发器指的是在更新时会检查整个表的状态,根据查询结果执行触发动作。它们只在执行完整个SQL语句后才会被触发。Statement-Level触发器通常用于限制整表数据范围。下面是一个简单的Statement-Level触发器的例子:

CREATE OR REPLACE TRIGGER trg_statement

AFTER

INSERT OR UPDATE OR DELETE ON tab1

BEGIN

SELECT avg(col1) INTO avg_col1

FROM tab1;

IF avg_col1 > 100 THEN

RAISE_APPLICATION_ERROR(-20000, ‘avg value cannot exceed 100’);

END IF;

END;

/

综上所述,Oracle触发器可以被分为三种类型:before/after触发器,row-level触发器和statement-level触发器。before/after触发器用于执行每一行之前/之后的动作;row-level触发器用于检查每一行的发生并决定触发动作;而statement-level触发器用于检查整个表并决定触发动作。这三种触发器各有优劣,每か一的场合了解它们的用法并利用它们将有助于我们更好更高效地开发和管理数据库。