DB2触发器

文章展示了在DB2数据库中创建三种触发器的语法:用于检查员工薪水的tri_emp_sal_check,记录CurrentRate表中rate变化的RecordHistory,以及更新rate状态的RateStatus。这些触发器在数据更新时自动执行,确保数据完整性并维护额外的信息记录。
摘要由CSDN通过智能技术生成
CREATE TRIGGER tri_emp_sal_check
NO cascade BEFORE
INSERT /*OR UPDATE*/ ON test.EMP
REFERENCING NEW AS newemp
FOR EACH ROW
MODE DB2SQL
SET newemp.SAL = CASE WHEN newemp.SAL <100 THEN 100
END


CREATE TRIGGER RecordHistory

AFTER

UPDATE OF rate ON test.CurrentRate

REFERENCING NEW AS newrate FOR EACH ROW

MODE DB2SQL

BEGIN ATOMIC INSERT INTO RateHistory VALUES (newrate.id, newrate.name, newrate.rate, current timestamp) ;

END

CREATE TRIGGER RateStatus

NO CASCADE BEFORE

UPDATE OF rate ON test.CurrentRate

REFERENCING OLD AS oldrate NEW AS newrate

FOR EACH ROW

MODE DB2SQL

SET newrate.status= CASE WHEN newrate.rate>=(select max(rate) from ratehistory where id=newrate.id) THEN 'Highest' WHEN newrate.rate<=(select min(rate) from ratehistory where id=newrate.id) THEN 'Lowest' WHEN newrate.rate>oldrate.rate THEN 'Rising' WHEN newrate.rate<oldrate.rate THEN 'Dropping' WHEN newrate.rate=oldrate.rate THEN 'Steady'

END
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值