• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    oracle 触发器 实现出入库
    用语言实现
    好处:
    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触发器实例代码
    • Oracle触发器表发生了变化 触发器不能读它的解决方法(必看)
    • Oracle使用触发器和mysql中使用触发器的案例比较
    • Oracle触发器用法实例详解
    • Oracle中使用触发器(trigger)和序列(sequence)模拟实现自增列实例
    • oracle监控某表变动触发器例子(监控增,删,改)
    • [Oracle] 如何使用触发器实现IP限制用户登录
    • oracle 存储过程和触发器复制数据
    • oracle 触发器 学习笔记
    • 详解oracle中通过触发器记录每个语句影响总行数
    上一篇:oracle 树查询 语句
    下一篇:oracle 删除重复数据
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    oracle 触发器 实现出入库 oracle,触发器,实,现出,入库,