欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Oracle数据库触发器数据的确认

程序员文章站 2022-05-08 20:29:50
...

一 需求

涨工资不能越涨越少。
 
二 代码
  1. --触发器应用场景2:数据的
  2. --涨后的薪水不能少于涨前的薪水
  3. /*
  4. :old和:new代表的是同一条记录
  5. :new 表示操作该行之前,这一行的值
  6. :old 表示操作该行之后,这一行的值
  7. */
  8. create or replace trigger checksalary
  9. before update
  10. on emp
  11. for each row
  12. begin
  13. if:old.sal >:new.sal then
  14. raise_application_error(-20002,'涨后的薪水不能少于涨前的薪水 涨前'||:old.sal||'涨后'||:new.sal);
  15. endif;
  16. end;
  17. /
 
三 验证
SQL> update emp set sal=sal+1 where empno=7839;
 
已更新 1 行。
 
SQL> update emp set sal=sal-1 where empno=7839;
update emp set sal=sal-1 where empno=7839
       *
第 1 行出现错误:
ORA-20002: 涨后的薪水不能少于涨前的薪水 涨前10101涨后10100
ORA-06512: 在 "SCOTT.CHECKSALARY", line 3
ORA-04088: 触发器 'SCOTT.CHECKSALARY' 执行过程中出错