Oracle database triggers are activated during DDL (such as CREATE, ALTER) or DML (such as INSERT, UPDATE, DELETE) operations: DDL operations activate triggers defined on the underlying table. DML operations activate triggers defined on the underlying table.
Oracle database trigger activation
Method to activate trigger
Oracle database triggers can be automatically activated in the following two situations:
Trigger activation example
To illustrate trigger activation, we create a simple example table and a trigger defined on the table:
-- 创建示例表 CREATE TABLE employees ( id NUMBER PRIMARY KEY, name VARCHAR2(50), salary NUMBER ); -- 定义触发器 CREATE TRIGGER salary_check BEFORE UPDATE ON employees FOR EACH ROW BEGIN IF NEW.salary < 0 THEN RAISE_APPLICATION_ERROR(-20001, 'Salary cannot be negative'); END IF; END;
Now when we try to update the employee table using DML operation, the trigger will be activated and executed:
-- 尝试更新员工的薪水为负值 UPDATE employees SET salary = -100 WHERE id = 1; -- 触发器将引发错误并回滚操作 ORA-20001: Salary cannot be negative
Points to note
The above is the detailed content of How to activate oracle database trigger. For more information, please follow other related articles on the PHP Chinese website!