学习Oracle数据库中的触发器类型(oracle触发器类型)


Oracle 数据库中的触发器类型可以被用在很多不同的编程领域,它们可以被用于做各种自动化任务,如果熟悉Oracle触发器类型也能很快地实现一些高级的程序。

首先,我们需要了解OCRacle 提供的触发器的类型,有2种: row trigger 和statement trigger。前者在每行被改变时,后者则是在一整句被改变时。

row trigger 用于检测每行数据发生的变化,它可以监控表的插入、更新或者删除操作。其工作原理主要是它可以监控关联的表中的每行数据,每当这些数据发生变化时,就会触发该触发器。例如:

“`SQL

CREATE OR REPLACE TRIGGER tr_tab1_before_update

BEFORE UPDATE ON tab1

FOR EACH ROW

BEGIN

IF :new.x :old.x THEN

— do something

END IF;

END;


statement trigger 在一条语句被改变时触发,它监视表上的INSERT、UPDATE或删除。它通常用于在一组操作之前或之后运行特定的语句。其工作原理主要是它可以监控关联的表上开始或结束一组操作的完成情况,如果表上的某一组操作开始或结束,那么它就会触发该触发器,完成相应的操作。例如:

```SQL
CREATE OR REPLACE TRIGGER tr_tab1_before_statement
BEFORE INSERT OR DELETE OR UPDATE ON tab1
BEGIN
-- Do something
END;

Oracle触发器的类型也可以分为两种,由于它在许多不同的应用中都为我们提供了很多方便,熟悉这类型触发器对于灵活应对不同情况非常有用。只要明确触发条件和执行动作,就可以通过编程实现触发器监控表的操作,从而实现自动化任务。