如何解决PL/SQL 创建触发器,检查表中是否有记录
我正在创建汽车租赁/汽车共享数据库。 我想创建触发器来检查是否有活动租赁,通过检查租赁结束是否为空,如果它为空,然后如果它不为空,如果它具有相同的汽车 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;
解决方法
为什么要触发?一旦有人想租车,为什么不在应用程序中进行?
触发器应该raise_application_error
。不要使用 dbms_output.put_line
因为没有前端应用程序(我使用过)能够向用户显示其内容(并且我假设您不会直接在 SQL*Plus 或 SQL Developer 中操作数据,但是例如Apex 或表单应用程序)。
此外,您想要这样做的方式会导致 mutating table 错误 - 您正在插入 rentals 表并从中选择(在触发器中) ;这是不允许的,因为表是变异。是的,有很多方法可以避免它,但大多数情况下,您看到该错误时必须问自己是否做得对正确。在我看来,您正在尝试错误。
顺便说一下,你说这话是什么意思:
...通过检查租赁结束是否为空,如果为空,则如果不为空
嗯?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。