在更新 Oracle 11g 后通过触发器更新值

Updating value via trigger AFTER UPDATE Oracle 11g(在更新 Oracle 11g 后通过触发器更新值)
本文介绍了在更新 Oracle 11g 后通过触发器更新值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在开发一个小型图书馆数据库,我不想让某人更新某人的 ID.但我需要使用 AFTER UPDATE 和 FOR EACH STATEMENT(有人告诉我这是 Oracle 的默认设置).因此,基本上,如果有人更新了客户信息并更改了他/她的 ID 或输入错误,触发器会自动将其再次更新为旧值.问题是在使用 FOR EACH STATEMENT 时,Oracle 不允许我使用 :NEW 和 :OLD.这个问题有什么解决方法吗?

I'm developing a small library database and I don't want to allow someone to update someone's ID. But I need to use AFTER UPDATE and FOR EACH STATEMENT (which I'm told is Oracle's default). So, basically, if someone updates the customer info and alter his/her ID or mistypes it, the trigger will automatically update it again to the old value. The problem is that Oracle won't let me use :NEW and :OLD when using FOR EACH STATEMENT. Are there any workarounds to this issue?

CREATE OR REPLACE TRIGGER alter_id_trigger
AFTER UPDATE ON CUSTOMER
BEGIN
   UPDATE CUSTOMER SET ID = :OLD.ID
   WHERE ID = :NEW.ID;
END;

谢谢!

推荐答案

使用以下代码触发.已完成更改:

  1. 使用 BEFORE UPDATE 而不是 AFTER UPDATE.
  2. 将 ID 的值设置为之前的值.(永远不会修改 ID 字段)

  1. Using BEFORE UPDATE instead of AFTER UPDATE.
  2. Setting the value of ID to what it was previously. (The ID Field would never be modified)

创建或替换触发器 ALTER_ID_TRIGGER在客户更新之前开始设置 :NEW.ID = :OLD.ID结束;

注意:更新前:一>

Note: With BEFORE UPDATE:

  • 您不能在视图上创建 BEFORE 触发器.
  • 可以更新 :NEW 值.
  • 无法更新 :OLD 值.
  • You can not create a BEFORE trigger on a view.
  • You can update the :NEW values.
  • You can not update the :OLD values.

这篇关于在更新 Oracle 11g 后通过触发器更新值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)