ORACLE触发器:在insert之前,判断这条插入语句是否可插入,不可插入时抛异常........

CREATE OR REPLACE TRIGGER "RQC_RECORD_TRI_INS" 
BEFORE insert ON RQC_RECORD
FOR EACH ROW
DECLARE
    NEW_TIME VARCHAR2(8);
    START_TIME VARCHAR2(8);
    END_TIME VARCHAR2(8);
    INSERT_EXCE exception;
BEGIN      
    NEW_TIME := to_char(sysdate,'hh24:mi');
    select starttime into START_TIME from rqc_worktime;
    select endtime into END_TIME from rqc_worktime;
    
    
    -- dbms_output.put_line(:new.recordtypeno);
    -- 得到要插入行的recordtypeno是否为开关机,并且判断当前时间是否为营业时间,如果条件都成立则不让插入数据,抛出异常
    if ((:new.recordtypeno = '010' or :new.recordtypeno = '011') and (NEW_TIME >= START_TIME and NEW_TIME <= END_TIME)) 
    then raise INSERT_EXCE; 
      
    end if;
   -- exception when INSERT_EXCE then dbms_output.put_line('在营业时间内进行正常开关机'); 
    exception when INSERT_EXCE then raise_application_error('-20002', '在营业时间内进行正常开关机');
    

END;

注::new可获取插入的字段值。

       raise_application_error用来抛异常,阻止插入。

       oracle中时间可以比较大小。

      to_char(sysdate,'hh24:mi');可以获取当前时间,后面的为格式。



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值