触发器是当特定事件出现时自动执行的存储过程,特定事件可以是执行更新的DML语句和DDL语句,触发器不能被显式调用;
触发器的功能:
自动生成数据;
自定义复杂的安全权限;
提供审计和日志记录;
启用复杂的业务逻辑;
创建trigger语法:
CREATE [OR REPLACE] TRIGGER trigger_name
AFTER | BEFORE | INSTEAD OF
[INSERT] [[OR] UPDATE [OF column_list]] [[OR] DELETE]
ON table_or_view_name
[REFERENCING {OLD [AS] old / NEW [AS] new}]
[FOR EACH ROW]
[WHEN (condition)]
pl/sql_block;
触发器由三部分组成:
1,触发器语句(事件):
定义激活触发器的 DML 事件和 DDL 事件;
2,触发器限制:
执行触发器的条件,该条件必须为真才能激活触发器;
3,触发器操作(主体):
包含一些 SQL 语句和代码,它们在发出了触发器语句且触发限制的值为真时运行;
例:
CREATE OR REPLACE TRIGGER aiu_itemfile
AFTER INSERT ON itemfile
FOR EACH ROW
BEGIN
IF (:NEW.qty_hand = 0) THEN
DBMS_OUTPUT.PUT_LINE('警告:已插入记录,但数量为零');
ELSE
DBMS_OUTPUT.PUT_LINE(‘已插入记录');
END IF;
END;
/