Oracle-触发器

触发器的应用场景

  • 复杂的安全性检查
  • 2数据确认
  • 实现审计功能
  • 完成数据的备份和同步

触发器的语法(本质是plsql程序)

触发器的类型

语句级触发器和行级触发器

触发器
数据库触发器是一个与表相关联的、存储的额PL/SQL程序
每当一个特定的数据操作语句(insert、update、delete)在指定的表上发出时,
oracle自动地执行触发器中定义的语句序列。

创建触发器

create trigger saynewwemp
after insert
on emp
declare
begin
dbms_output.put_line(‘成功插入新员工’);
end

触发器的语法的类型

创建触发器的语法

CREATE [or REPLACE] TRIGGER 触发器名
{BEFORE|AFTER}
{DELETE|INSERT|UPDATE[OF 列名]}
ON 表名
[FOR EACH ROW[WHEN(条件)]] –行级触发器特有–
PLSQL 块

触发器的类型

语句级触发器

在指定的操作语句操作之前或之后执行一次,不管这条语句
影响了多少行
针对的是表

行级触发器

触发语句作用的每一条记录都被出发。在行级触发器中使用
:old和:new伪记录变量,识别值的状态。
针对的是行

–触发器1:实施复杂的安全性检查–

–禁止在非工作时间插入新员工–
/*
1.周末: to_char(sysdate,’day’) in (‘星期六’,’星期日’)
2.上班前和下班后:to_number (to_char(sysdate,’hh24’)) not between 9 and 18

*/

create or replace trigger securityemp
before insert
on emp
declare
begin
if to_char(sysdate,'day') in ('星期六','星期日') or
to_number (to_char(sysdate,'hh24')) not between 9 and 18 then
--禁止Insert新员工
raise application_error(-20001,'禁止在非工作时间插入新员工');
end if;
end;
/

/*

触发器案例二:数据的确认

涨后的薪水不能少于涨前的薪水
:old 和 :new 代表同一条记录
:old 表示操作该行之前,这一行的值
:new 表示操作改行之后,这一行的值
*/

create or replace trigger checksalary
before update
on emp
for each row
begin
--if 涨后的薪水 < 涨前的薪水 then
if :new.sal < :old.sal then
raise_application_error(-20002,'涨后的薪水不能少于涨前的薪水
,涨后的薪水'||:new.sal||"涨前的薪水:"||:old.sal);
end;
/

/*

触发器应用场景三:数据库的审计–>基于值的审计功能

给员工涨工资,当涨后的薪水超过6000块时候,审计该员工的信息

*/
–创建表,用于保存审计信息
create table audit_info
(
infomation varchar2(200);
);

create or replace trigger do_audit_emp_salary
after update
on emp
for each row
begin
--当涨后薪水大于6000,插入审计信息
if:new.sal > 6000 then
insert into audit _info (:new.empno||' '||:new.ename||' '|| :new.sal);
end if;
end;
/

/*

触发器应用场景四:数据的备份和同步

当给员工涨完工资后,自动备份信息的工资到备份表中
*/

create or replace trigger sync_salary
after update
on emp
for each row
begin
--当主表更新后,自动更新备份表
update emp_back set sal=:new.sal where empno=:new.empno;
end;
/

触发器是同步备份,快照是一步备份

你可能感兴趣的:(ORACLE学习)