Oracle 触发器的种类与特征(oracle触发器类型)


Oracle触发器允许程序员指定在特定的数据更改发生时要执行的行为。一般而言,Oracle触发器有两种类型:表触发器和数据库触发器。

表触发器是与指定表关联的触发器,它用于响应对表中数据的INESRT,UPDATE或DELETE操作。其通常形式为:CREATE [OR REPLACE] TRIGGER trigger_name BEFORE | AFTER [INSERT|UPDATE|DELETE] ON table_name [FOR EACH ROW] BEGIN —–trigger body END; 语句,其中的trigger_name为触发器的名字;在该句中,BEFORE | AFTER关键字指定触发器的时间点:BEFORE表示当关联的事件发生前触发器将发生,AFTER表示当关联的事件发生后触发器将发生,[INSERT | UPDATE | DELETE]表示触发器的操作,FOR EACH ROW表示每一行触发一次,trigger_body为触发器的主体,而” trigger body begin” 和 “end” 是指准备要输入到触发器主体当中的代码。

数据库触发器是一种定义在数据库级别的触发器,用于响应数据库权限,模式,日志等事件。语法为:CREATE [OR REPLACE] TRIGGER trigger_name [BEFORE|AFTER] event_name ON DATABASE BEGIN —–trigger_body END; 一般情况下,其中BEFORE | AFTER关键字用于指定触发器在事件触发之前或之后发生;trigger_name 是触发器的名称,event_name表示要触发的事件的名称,trigger_body 为触发器的代码。

无论是表触发器还是数据库触发器,其具有三个基本特征:1)触发时间,即关联的事件发生的特定的时间点;2)封装业务逻辑,将一些管理对象的逻辑永久地保存在数据库中;3)自动执行,因为在满足特定条件时,触发器会自动执行。

总而言之,Oracle触发器可以检测关联的数据变更行为并执行特定的操作,它可以为程序员提供灵活的操作方式,有效地管理数据库的维护和安全管理工作。