oracle 触发器 new ,old


特性 INSERT UPDATE DELETE

OLD NULL 实际值 实际值

NEW 实际值 实际值 NULL
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle触发器是一种特殊的存储过程,它会在数据库中的表发生特定事件时自动执行。触发器可以在INSERT、UPDATE和DELETE操作之前或之后自动运行,以便在数据更改时执行自定义逻辑。下面是Oracle触发器的详细介绍: 1. 触发器类型 Oracle触发器分为BEFORE和AFTER两种类型。BEFORE触发器会在执行INSERT、UPDATE或DELETE操作之前自动运行,而AFTER触发器则会在执行完操作后自动运行。 2. 触发器事件 触发器事件是触发器执行的事件类型。Oracle触发器支持以下事件类型: - INSERT:在插入新行之前或之后触发。 - UPDATE:在更新行之前或之后触发。 - DELETE:在删除行之前或之后触发。 3. 触发器语法 Oracle触发器的语法如下: CREATE [ OR REPLACE ] TRIGGER trigger_name { BEFORE | AFTER } { INSERT | UPDATE | DELETE } ON table_name [ FOR EACH ROW ] [ WHEN (condition) ] BEGIN -- 触发器代码 END; - trigger_name:触发器名称。 - BEFORE / AFTER:触发器类型。 - INSERT / UPDATE / DELETE:触发器事件类型。 - table_name:要监视的表名。 - FOR EACH ROW:指定触发器为每一行执行。 - WHEN:指定触发器执行的条件。 - 触发器代码:要执行的代码。 4. 触发器使用示例 下面是一个Oracle触发器的示例,它会在每次更新“employees”表中的“salary”字段时将更新记录插入到“salary_history”表中: CREATE OR REPLACE TRIGGER salary_history_trigger AFTER UPDATE OF salary ON employees FOR EACH ROW BEGIN INSERT INTO salary_history (employee_id, old_salary, new_salary, update_time) VALUES (:OLD.employee_id, :OLD.salary, :NEW.salary, SYSDATE); END; 这个触发器会在每次更新“employees”表中的“salary”字段时自动执行,并将更新记录插入到“salary_history”表中,以便记录历史薪资信息。 总之,Oracle触发器可以在数据库中的表发生特定事件时自动执行,让我们能够通过自定义逻辑来处理数据变化。但是,在使用触发器之前应该仔细考虑其影响,以确保不会对系统性能和数据完整性造成负面影响。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值