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

前端之家收集整理的这篇文章主要介绍了Oracle数据库触发器数据的确认前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

一 需求

涨工资不能越涨越少。
代码
  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' 执行过程中出错

猜你在找的Oracle相关文章