oracle 触发器 实现出入库

所属分类: 数据库 / oracle 阅读数: 79
收藏 0 赞 0 分享
用语言实现
好处:
1、可以减少对数据库的访问。
2、可移植性好。
坏处:
1、操作起来考虑的东西较多,修改一处就要修改别一处。也就是说是相互关联的。如果少改了某一处,很可能使数据不一致。
用触发器实现
好处:
1、可以使程序员从复杂的相互关联中解放出来,把精力放在复杂的业务上。
坏处:
1、可移植性差。
下面我就用一个例子实现一个简单的出入库。因为是例子表中所用到的字段很少。这里的例子只做为抛砖引玉。
数据表为入库金额表(以下简称入库表)income,出库金额表(以下简称出库表)outlay,余额表balance
复制代码 代码如下:

income{
id number;
pay_amount number;(入库金额字段)
}
outlay{
id number;
outlay_amount number;(出库金额字段)
}
balance
{
id number;
balance number;(余额字段)
}

下面分别在入库和出库表中建立触发器
入库表(income):
复制代码 代码如下:

CREATE TRIGGER "AA"."TRI_ADD" AFTER
INSERT
OR DELETE ON "INCOME" FOR EACH ROW begin
if deleting then
update balance set balance = nvl(balance,0) - :old.pay_amount;
elsif updating then
update balance set balance = nvl(balance,0) - :old.pay_amount + :new.pay_amount;
else
update balance set balance = nvl(balance,0) + :new.pay_amount;
end if;
end;

出库表(outlay):
复制代码 代码如下:

CREATE TRIGGER "AA"."TRI_CUT" AFTER
INSERT
OR DELETE
OR UPDATE ON "OUTLAY" FOR EACH ROW begin
if deleting then
update balance set balance = nvl(balance,0) + :old.outlay_amount;
elsif updating then
update balance set balance = nvl(balance,0) + :old.outlay_amount - :new.outlay_amount;
else
update balance set balance = nvl(balance,0) - :new.outlay_amount;
end if;
end;

下面我解释一下
oracle触发器,触发事件分为插入,删除,更新列三种事件,分别对应inserting /deleting/updating关键字
可以用if语句分别实现
复制代码 代码如下:

if inserting then
-----
elsif updating then
-----
elsif deleting then
------
end if;

NVL(eExpression1, eExpression2)
如果 eExpression1 的计算结果为 null 值,则 NVL( ) 返回 eExpression2。
如果 eExpression1 的计算结果不是 null 值,则返回 eExpression1。eExpression1 和 eExpression2 可以是任意一种数据类型。
如果 eExpression1 与 eExpression2 的结果皆为 null 值,则 NVL( ) 返回 .NULL.。
这里插入和删除就不说了。主要是更新操作,更新操作要注意的是更新应该是先减去旧值,在加上新值。
以上就是触发器例子的实现。文章写的不好请大家谅解。
更多精彩内容其他人还在看

Oracle parameter可能值获取方法

有时不清楚一些参数的所有允许设定的值,比如Oracle中parameter,接下来介绍两种方法获取Oracle中parameter的可能值,需要了解的朋友可以参考下
收藏 0 赞 0 分享

ORACLE锁机制深入理解

若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性,加锁是实现数据库并发控制的一个非常重要的技术,需要的朋友可以了解下
收藏 0 赞 0 分享

Oracle 细粒度审计(FGA)初步认识

细粒度审计(FGA),是在Oracle 9i中引入的,能够记录SCN号和行级的更改以重建旧的数据,本文将详细介绍,需要的朋友可以参考下
收藏 0 赞 0 分享

delete archivelog all无法清除归档日志解决方法

最近在因归档日志暴增,使用delete archivelog all貌似无法清除所有的归档日志,究竟是什么原因呢?本文将为您解答,需要的朋友可以参考下
收藏 0 赞 0 分享

Oralce数据导入出现(SYSTEM.PROC_AUDIT)问题处理方法

A数据库打开了审计,而导入到B数据库时,B数据库审计没有打开,数据库中没有SYSTEM.PROC_AUDIT对象,本文将此问题的解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

win7安装oracle10g 提示程序异常终止 发生未知错误

本文将详细介绍oracle 10g 在win7下安装提示程序异常终止,发生未知错误的解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

WMware redhat 5 oracle 11g 安装方法

本文将详细介绍WMware中redhat 5 安装oracle 11g方法,需要的朋友可以参考下
收藏 0 赞 0 分享

oracle 数据泵导入导出介绍

本文将介绍oracle数据泵导导出步骤详细介绍,需要的朋友可以参考下
收藏 0 赞 0 分享

oracle 合并查询 事务 sql函数小知识学习

oracle 合并查询 事务 sql函数小知识学习,需要的朋友可以参考下
收藏 0 赞 0 分享

RAC cache fusion机制实现原理分析

本文将详细介绍RAC cache fusion机制实现原理,需要了解更多的朋友可以参考下
收藏 0 赞 0 分享
查看更多