Welcome to the website navigation,本站只接受合法正规的企业网站,欢迎站长们提交你的网站获得展示和流量有任何问题请联系站长,欢迎大家加入本站。

                
提交网站
  • 网站:76083
  • 待审:5
  • APP:577
  • 文章:304416
  • 会员:56004
文字内链包年1000元 文字内链包年1000元 文字内链包年1000元 AI办公网站 AI绘画工具 AIchat

名站网址导航为大家提供关于数据库教程相关的教程网站知识。

oracle 树查询 数据库语句qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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

复制具体相关代码 具体相关代码如下:qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


income{
id number;
pay_amount number;(入库金额字段)
}
outlay{
id number;
outlay_amount number;(出库金额字段)
}
balance
{
id number;
balance number;(余额字段)
}
qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


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

复制具体相关代码 具体相关代码如下:qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


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;
qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


出库表(outlay):

复制具体相关代码 具体相关代码如下:qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


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;
qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


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

复制具体相关代码 具体相关代码如下:qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


if inserting then
-----
elsif updating then
-----
elsif deleting then
------
end if;
qKoAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!


NVL(eExpression1, eExpression2)
假如如果 eExpression1 的计算结果为 null 值,则 NVL( ) 返回 eExpression2。
假如如果 eExpression1 的计算结果不是 null 值,则返回 eExpression1。eExpression1 和 eExpression2 可以是任意一种数据类型。
假如如果 eExpression1 与 eExpression2 的结果皆为 null 值,则 NVL( ) 返回 .NULL.。
这里插入和删除就不说了。主要是更新操作办法,更新操作办法要注意的是更新应该是先减去旧值,在加上新值。
以上就是触发器例子的实现。文章写的不好请大家谅解。 关于数据库教程相关的教程网站知识今天我们就说到这里了,希望可以帮到大家。

标签:

分享到:

  网友投稿

注册时间:

网站:0 个   APP:0 个  文章:0 篇

  • 76083

    网站

  • 577

    APP

  • 304416

    文章

  • 56004

    会员

赶快注册账号,推广您的网站吧!
文章分类
热门网站
最新入驻APP小程序

宝贝市场2023-02-08

宝贝市场——买手和卖家商品展示

夺宝助手2023-02-08

夺宝助手小程序,查看每日快夺宝平

查诚信2023-02-08

查诚信是一款免费的商业查询工具

车价天天报2023-02-08

快速连接汽车销售,获知汽车最新报

考勤助理小程序2023-02-08

上班签到考勤,实时定位,后台轻松

汽车报价大全查询2023-02-08

汽车报价大全查询提供最新汽车市