微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PL/SQL 创建触发器,检查表中是否有记录

如何解决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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?