初探Oracle触发器:解析常见触发器类型(oracle触发器类型)


及原理

Oracle触发器是一种特殊的存储程序起另一种特殊的功能:当满足指定条件时,就会自动被触发执行,不需要开发者手动操作。它可以实现数据的自动完成更新、避免由于数据更新发生的不一致状态;使用触发器可以解决数据完整性、安全性和一致性问题。Oracle中的触发器主要有以下几种类型:

一、行级触发器

行级触发器是指操作发生在某一行记录上时触发的触发器。Oracle以下操作会触发行级触发器:INSERT、UPDATE、DELETE和Merge操作,它包括表触发器(Table Trigger)及表视图触发器(View Trigger)。

表触发器:

以下是一个表触发器的实现代码:

“`sql

create trigger tg_empId

after insert or update or delete on EmpId

for each row

begin

if inserting then

dbms_output.put_line(‘新的员工ID:’ || :new.empId);

end if;

end;

/


以上代码创建一个名为tg_empId的表触发器,当向EmpId表插入一条记录时,就会触发此触发器,将插入的新记录ID输出到控制台上。

表视图触发器:

Oracle支持在表视图上建立触发器,下面是一段关于表视图触发器的实现代码:

```sql
create or replace view EmpView as
select * from EmpId;

create trigger tg_empview
after insert or update or delete on EmpView
for each row
begin
if inserting then
dbms_output.put_line('新的员工ID:' || :new.empId);
end if;
end;
/

以上触发器的功能与表触发器相同,只是触发前的操作对象不同,这里即表视图EmpView。

二、级联触发器

级联触发器是在DML操作对象之外还触发其他DML操作,当触发器运行完毕后,会把作用扩大到其他表上,使这些表也有一样的内容或数据变化,以下是一个级联触发器实现代码:

“`sql

create trigger tg_emp

after update of salary on EmpId

referencing new as new_data

for each row

begin

update SalaryHistory

set history_salary = :new_data.salary

where emp_id = :new_data.emp_id;

end;

/


以上代码创建了一个tg_emp级联触发器,当EmpId表中的salary字段值发生更新时,将触发此触发器,同时更新SalaryHistory表中的history_salary字段,使薪水值统一更新。

三、代码触发器

代码触发器是指在某一时间点上被触发执行,它可以满足日、周、月等定时调度的要求,如果使用它来检查数据库表或表中的数据,就可以避免由于数据更新发生的不一致。以下是一段代码触发器的实现代码:

```sql
create or replace trigger tg_time
after systimestamp
begin
dbms_output.put_line('执行时间:' || systimestamp);
update SalaryHistory
set history_salary = (
select salary from Empid
);
end;
/

以上代码创建了一个不需要关联表的代码触发器,当系统发生时间点变化时,触发器就会被触发,将系统时间和更新SalaryHistory表中的history_salary字段输出到控制台中。

总结

以上就是Oracle触发器的几种类型及原理,Oracle触发器可以有效解决由于数据更新发生的不一致性问题,还可以实现安全性和一致性的维护,提高数据访问的效率。