oracle触发器中判断记录是否为空

我开始写了一个触发器,要判断SSO_SP_LIST表中MASTER_SESS_ID字段值与我要在SSO_MASTERS_INF
表中删除的记录的MASTER_SESS_ID字段值相等的记录是否为空,我select了该记录的MASTER_SESS_ID字段,放入变量v(字段MASTER_SESS_ID类型),判断if v is not null,结果v为空时,触发器执行到这里就出错。

于是我将变量改为整型,让它返回记录的count值,判断是否大于0,ok,触发器照我的想法跑了,嘿嘿。

原来出错的触发器:

CREATE OR REPLACE TRIGGER TIG_BEF_DELETE_SSO_MASTERS
BEFORE DELETE
ON SSO_MASTERS_INF

FOR EACH ROW
DECLARE
   V SSO_SP_LIST.MASTER_SESS_ID%TYPE
BEGIN
   UPDATE SSO_MASTERS_HIS SET SSO_MASTERS_HIS.TIME_EXIT=SYSDATE WHERE SSO_MASTERS_HIS.MASTER_SESS_ID=:OLD.MASTER_SESS_ID;
   SELECT MASTER_SESS_ID INTO V FROM SSO_SP_LIST WHERE SSO_SP_LIST.MASTER_SESS_ID=:OLD.MASTER_SESS_ID;

   IF V IS NOT NULL THEN
       DELETE FROM SSO_SP_LIST WHERE MASTER_SESS_ID=:OLD.MASTER_SESS_ID;
       UPDATE SSO_SP_LIST_HIS SET TIME_SP_EXIT=SYSDATE WHERE MASTER_SESS_ID=:OLD.MASTER_SESS_ID;
   END IF;
end TIG_BEF_DELETE_SSO_MASTERS;

修改后的触发器

CREATE OR REPLACE TRIGGER TIG_BEF_DELETE_SSO_MASTERS
BEFORE DELETE
ON SSO_MASTERS_INF

FOR EACH ROW
DECLARE
   V int;
BEGIN
   UPDATE SSO_MASTERS_HIS SET SSO_MASTERS_HIS.TIME_EXIT=SYSDATE WHERE SSO_MASTERS_HIS.MASTER_SESS_ID=:OLD.MASTER_SESS_ID;
   SELECT count(*) INTO V FROM SSO_SP_LIST WHERE SSO_SP_LIST.MASTER_SESS_ID=:OLD.MASTER_SESS_ID;

   IF V >0 THEN
       DELETE FROM SSO_SP_LIST WHERE MASTER_SESS_ID=:OLD.MASTER_SESS_ID;
       UPDATE SSO_SP_LIST_HIS SET TIME_SP_EXIT=SYSDATE WHERE MASTER_SESS_ID=:OLD.MASTER_SESS_ID;
   END IF;
END TIG_BEF_DELETE_SSO_MASTERS;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值