0

我正在创建汽车租赁/汽车共享数据库。我想创建一个触发器来检查是否有活动的租赁,通过检查租赁结束是否为空,如果它为空,那么如果它不为空,它是否具有相同的汽车 ID。我不知道如何创建该触发器...感谢您的任何建议。

create or replace TRIGGER act_rental_trigger
BEFORE INSERT ON "RENTALS" 
FOR EACH ROW 
DECLARE 
end_of_rental date;
BEGIN  
   IF inserting THEN 
    IF end_of_rental IS NOT NULL THEN 
   IF (EXISTS ( 
      SELECT * FROM rentals 
      where rentals.car_id = :NEW.car_id ))
         THEN 
         dbms_output.put_line('You can't!'); 
    END IF; 
    END IF;
   END IF;
END;
4

1 回答 1

0

为什么触发?一旦有人想租车,你为什么不在应用程序中做呢?

触发器应该raise_application_error。不要使用dbms_output.put_line,因为没有前端应用程序(我使用过)能够向用户显示其内容(并且我假设您不会直接在 SQL*Plus 或 SQL Developer 中操作数据,但例如 Apex 或 Forms 应用程序) .

此外,您想要这样做的方式会导致变异表错误 - 您正在插入到出租表中并从中选择(在触发器中);这是不允许的,因为 table is mutating。是的,有一些方法可以避免它,但大多数情况下,你看到这个错误,你必须问自己是否做了。在我看来,你试图做错了


顺便说一句,你这样说是什么意思:

...通过检查租赁结束是否为空,如果它为空,那么如果它不为空

嗯?

于 2021-01-09T20:13:50.337 回答