触发器游标详解.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
触发器游标详解

创建触发器 为了演示触发器的功能,下面再引入一个简易仓库管理的例子。在采购配件前,必须首先制定采购计划(如采购计划表 PlanA),然后交由采购员采购,采购回来后,要将配件入库,入库时,除了要修改入库表(配件入库表 InStock)外,还要修改配件库存表(仓库库存表 Stock),还要修改采购计划表(采购计划表 PlanA),因为要修改实际完成的采购量(FinishQty)。三个数据表如下: 采购计划表 PlanA 备件入库表 InStock 备件库存表 Stock 给计划表追加如下数据 一、用企业管理器创建触发器 例1:对备件入库InStock表建立一个插入触发器utr_InStockIns,其功能为:备件入库时,除了要将入库数据追加到备件入库表(InStock)外,还要修改计划表(PlanA)中对应计划号的完成数量(增加FinishQty)和备件库存表(Stock)中对应备件代码的库存数量(StockQty)。 注:同企业管理器创建的触发器 例2:对备件入库表建立一个删除触发器utr_InStockDel,其功能为:删除备件入库中的记录时,除了要删除入库表(InStock)的记录外,还要修改计划表(PlanA)中对应计划号的完成数量(减少FinishQty),还要删除备件库存表(Stock)中对应备件代码的记录。 例3:对备件入库表建立一个更改除触发器utr_InStockUpt,其功能为:更改备件入库中的记录时,除了要更改入库表(InStock)的记录外,还要更改备件库存表(Stock)中对应备件代码的数据,同时,还要更改计划表(PlanA)中对应计划号的完成数量(FinishQty)。 触发器的应用 假设你已经按照 HYPERLINK 4.2.3.htm 4.2.3创建触发器中要求创建了插入触发器utr_InStockIns、删除触发器utr_InStockDel和更改触发器utr_InStockUpt,才能做下面的实验。 可以参见 HYPERLINK 4.2.4.htm 4.2.4管理触发器来检查是否已经创建。 一、插入型触发器的应用 假设采购计划表(PlanA)中的数据如下图,而备件入库表(InStock)和备件库存表(Stock)中没有数据。 现在打开备件入库表(InStock),向该表中追加1条记录,如下 ?然后打开计划表和备件库存表,查看是否发生了变化? 按照上面的方法,再向备件入库表(InStock)中追加几条记录,如下图 采购计划表中(PlanA)的数据变化如下 备件库存表(Stock)中的数据变化如下 ? ?注:结合上节建立的插入触发器,理解插入触发器的工作原理。 二、删除触发器的应用 假设你已经完成了“插入触发器的应用”中的例子。 打开备件入库表,删除下图中指示的记录 备件入库表(InStock)中的数据变化如下 采购计划表(PlanA)中的数据变化如下 备件库存表(Stock)中的数据变化如下 ?注:结合上节建立的删除触发器,理解删除触发器的工作原理。 三、更改触发器的应用 假设你已经完成了“插入触发器的应用”和“删除触发器的应用”中的例子。 打开备件入库表,更改下图中指示的记录 备件入库表(InStock)中的数据变化如下 采购计划表(PlanA)中的数据变化如下 备件库存表(Stock)中的数据变化如下 注:结合上节建立的更改触发器,理解更改触发器的工作原理。 注:由于我们直接在企业管理器中修改(插入、删除、更改)数据,每次修改一条记录后,当光标移到其它记录上或按“”执行后,系统就自动地调用了各自的触发器,且每次只有1条记录修改的记录。所以,在企业管理器中,无法测试一次修改多条记录的情况。 想一想:如何一次修改多条记录? 游标的使用 一、插入触发器utr_InStockIns存在的问题 如:在 HYPERLINK 4.2.3.htm 4.2.3创建触发器中创建的插入触发器utr_InStockIns,每次只支持插入一条记录。假如有一个结构与InStock完全相同的数据表InStockA,该表中有二条入库记录,如下 假设采购计划表(PlanA)中的数据如下图,而备件入库表(InStock)和备件库存表(Stock)中没有数据。 下面,在查询分析器中,一次向备件入库表(InStock)追加多条记录,其记录来自于刚才建立的InStockA中,如下 delete from PlanA delete from InStock delete from Stock 查看备件入库表(InStock),表中追加了2条记录,正确 再查看采购计划表(PlanA),表中只修改了最后一个入库编号的完成数量,有错误 查看备件库存表(Stock),表中追加了2条记录,正确 是什么原因造成上面的错误?下图是utr_InS

文档评论(0)

sb75290 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档