深入探索Oracle数据库触发器类型(oracle触发器类型)


Oracle数据库触发器是一种特殊的存储过程,它也是数据库的一种“自动化”程序。触发器可以在Oracle数据库引擎处理某些数据操作时被激活。它可以在插入、更新或删除数据时自动触发特定程序。根据MySQL官方文档,有以下几类触发器:

1.行级触发器:当修改表行时,触发器可以被激活,如果触发器定义了行级触发条件,那么只有满足该条件的行才会被触发执行。它可以应用在双表update、multi-table delete或insert操作中。

例如:

“`sql

CREATE OR REPLACE TRIGGER tr_Upd_Emp AFTER UPDATE ON EMPLOYEE FOR EACH ROW

DECLARE

BEGIN

INSERT INTO employee_audit VALUES

(:old.employee_id,:old.name,:old.age,sysdate,’UPDATE’);

END;


上面的触发器在更新表EMPLOYEE的任何行时被触发,触发器的动作是将一条新的记录提交到备份表employee_audit中。

2.语句级触发器:当对表进行插入、更新、删除等操作时,触发器可以被激活。如果触发器定义了这种触发条件,那么只有满足条件的操作才会被触发执行。

例如:

```sql
CREATE OR REPLACE TRIGGER tr_Del_Emp AFTER DELETE ON EMPLOYEE
DECLARE
BEGIN
INSERT INTO employee_audit VALUES
(:old.employee_id,:old.name,:old.age,sysdate,'DELETE');
END;

上面的触发器在从表EMPLOYEE删除任何行时被触发,触发器的动作是将一条新的记录提交到备份表employee_audit中。

3.语法触发器:它是一种强大的触发器,可以检查任何类型的SQL操作,包括查询、删除、更新和插入,而不仅仅是数据库对象。

例如:

“`sql

CREATE TABLE EMP_TBL

(

EMPLOYEE_ID VARCHAR2(11),

NAME VARCHAR2(30),

AGE NUMBER

);

CREATE OR REPLACE TRIGGER tr_emp_tbl

BEFORE INSERT OR UPDATE OR DELETE ON EMP_TBL

DECLARE

v_username VARCHAR2(30);

BEGIN

SELECT user_name INTO v_username FROM USERS;

IF INSERTING THEN

INSERT INTO AUDIT_TABLE VALUES (v_username, sysdate, ‘INSERT’);

ELSIF UPDATING THEN

INSERT INTO AUDIT_TABLE VALUES (v_username, sysdate, ‘UPDATE’);

ELSE

INSERT INTO AUDIT_TABLE VALUES (v_username, sysdate, ‘DELETE’);

END IF;

END;


上面的触发器对表EMP_TBL进行插入、更新、删除的操作时都会被触发,触发器的动作是将一条新的操作记录插入到AUDIT_TABLE中。

Oracle数据库触发器是一种强大的工具,可以满足各种自动化数据库操作的需求。在结构化查询语言(SQL)操作上,它可以提供强大的后处理自动化机制。在编写触发器时,要记住触发器的类型和功能,有助于编写时正确和有效地运行触发器。