Oracle数据库中触发器的类型及其应用(oracle触发器类型)


Oracle数据库中触发器是是一种特殊的数据库对象,它提供了一种没有使用存储过程的方式,对某特定动作下的数据库表进行影响操作。它可以定义在表、视图、至少一个列,甚至可以定义在表中的一组列上,该触发器会在一些特定的操作发生时采取,从而自动更新数据表。

Oracle数据库中触发器一共分为三种:

1、Row-level trigger

Row-level trigger可以在表中每行数据发生更新时执行触发器,对更新前状态执行操作。示例如下:

CREATE OR REPLACE TRIGGER update_row

AFTER UPDATE ON employee

FOR EACH ROW

BEGIN

UPDATE employee

SET last_name=:NEW.last_name

WHERE id=:NEW.id;

END;

2、Statement-level trigger

Statement-level trigger在发生表结构更改时只触发一次,而不管表中具体有多少行得到更新,示例如下:

CREATE OR REPLACE TRIGGER update_statement

AFTER UPDATE ON employee

BEGIN

UPDATE employee

SET last_name={update_name};

END;

3、Compound trigger

Compound trigger可以把row-level trigger和statement-level trigger的操作结合起来,使一段代码可以在触发器的多个时间点运行,也可以在多个时间点根据需要更改,示例如下:

CREATE OR REPLACE TRIGGER update_trigger

FOR UPDATE OF emp_name ON employee

COMPOUND TRIGGER

BEFORE STATEMENT IS

BEGIN

DBMS_OUTPUT.PUT_LINE(‘BEFORE STATEMENT’);

END BEFORE STATEMENT;

BEFORE EACH ROW IS

BEGIN

DBMS_OUTPUT.PUT_LINE(‘BEFORE EACH ROW’);

END BEFORE EACH ROW;

AFTER EACH ROW IS

BEGIN

DBMS_OUTPUT.PUT_LINE(‘AFTER EACH ROW’);

END AFTER EACH ROW;

AFTER STATEMENT IS

BEGIN

DBMS_OUTPUT.PUT_LINE(‘AFTER STATEMENT’);

END AFTER STATEMENT;

END update_trigger;

触发器可以很好地改善数据库的性能,并且可以实现自动化的功能。它的使用可以减少用户的工作量,节省时间,提高效率。例如,可以在用户向表中插入新记录时,使用触发器自动检查用户输入的数据,检查数据是否合法有效。另外,它还可以用来阻止用户执行不允许的操作,例如在某表中删除某列,从而保护数据库系统免受意外操作。

总之,Oracle数据库中的触发器是一种非常有用的技术,可以很好地改善数据库性能,让数据库操作变得更加方便快捷。