




已阅读5页,还剩6页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
创建触发器为了演示触发器的功能,下面再引入一个简易仓库管理的例子。在采购配件前,必须首先制定采购计划(如采购计划表 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)。触发器的应用假设你已经按照4.2.3创建触发器中要求创建了插入触发器utr_InStockIns、删除触发器utr_InStockDel和更改触发器utr_InStockUpt,才能做下面的实验。可以参见4.2.4管理触发器来检查是否已经创建。一、插入型触发器的应用假设采购计划表(PlanA)中的数据如下图,而备件入库表(InStock)和备件库存表(Stock)中没有数据。现在打开备件入库表(InStock),向该表中追加1条记录,如下然后打开计划表和备件库存表,查看是否发生了变化?按照上面的方法,再向备件入库表(InStock)中追加几条记录,如下图采购计划表中(PlanA)的数据变化如下备件库存表(Stock)中的数据变化如下注:结合上节建立的插入触发器,理解插入触发器的工作原理。二、删除触发器的应用假设你已经完成了“插入触发器的应用”中的例子。打开备件入库表,删除下图中指示的记录备件入库表(InStock)中的数据变化如下采购计划表(PlanA)中的数据变化如下备件库存表(Stock)中的数据变化如下注:结合上节建立的删除触发器,理解删除触发器的工作原理。三、更改触发器的应用假设你已经完成了“插入触发器的应用”和“删除触发器的应用”中的例子。打开备件入库表,更改下图中指示的记录备件入库表(InStock)中的数据变化如下采购计划表(PlanA)中的数据变化如下备件库存表(Stock)中的数据变化如下注:结合上节建立的更改触发器,理解更改触发器的工作原理。注:由于我们直接在企业管理器中修改(插入、删除、更改)数据,每次修改一条记录后,当光标移到其它记录上或按“”执行后,系统就自动地调用了各自的触发器,且每次只有1条记录修改的记录。所以,在企业管理器中,无法测试一次修改多条记录的情况。想一想:如何一次修改多条记录?游标的使用一、插入触发器utr_InStockIns存在的问题如:在4.2.3创建触发器中创建的插入触发器utr_InStockIns,每次只支持插入一条记录。假如有一个结构与InStock完全相同的数据表InStockA,该表中有二条入库记录,如下假设采购计划表(PlanA)中的数据如下图,而备件入库表(InStock)和备件库存表(Stock)中没有数据。下面,在查询分析器中,一次向备件入库表(InStock)追加多条记录,其记录来自于刚才建立的InStockA中,如下delete from PlanAdelete from InStockdelete from Stock查看备件入库表(InStock),表中追加了2条记录,正确再查看采购计划表(PlanA),表中只修改了最后一个入库编号的完成数量,有错误查看备件库存表(Stock),表中追加了2条记录,正确是什么原因造成上面的错误?下图是utr_InStockIns触发器源代码二、游标的使用使用每一个游标必须有四个组成部分,且这四个关键部分必须符合下面的顺序: DECLARE 游标 OPEN 游标 从一个游标中FETCH 信息 CLOSE 或DEALLOCATE 游标如何改进上面的程序,使之可以支持一次插入多个记录?在对采购计划表修改时,需要对备件入库的每一个记录数据(即插入表Inserted)进行扫描,然后逐一修改采购计划表中的完成数量。即我们需要对上图中,紫色区域的内容进行修改,修改后的程序如下对“一、插入触发器utr_InStockIns存在的问题”中所做的试验再做一遍,你会发现采购计划表中的数据得到了正确的修改。注:注意观察修改后的程序中是使用使用游标的,以及使用游标的四个关键部分。注:在上例中,我们针对utr_InStockIns存在的问题,使用游标得到了解决,想一想,在另外两个触发器中,是否也存在着同样的问题?如何改进?create trigger TR_Scoreinsert1on st_c_scorefor InsertASdeclare studentno nchar(10) ,courseno nchar(6), usually float ,final float ,teacher nchar(6) ,term nchar(10) ,xuenian nchar(10)select studentno=studentno ,courseno=courseno ,usually=usually , final=final ,teacher=teacher,term=term ,xuenian=xuenian from inserted declare cur_score cursor forselect studentno,courseno,usually, final ,teacher,term,xuenian from inserted open cur_scorefetch next from cur_score into studentno,courseno,usually,final,teacher,term,xuenianwhile fetch_status=0begininsert into score(studentno,courseno,usually,final,teacher,term,xuenian) values (studentno,courseno,usually
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年放射科医学影像诊断报告准确度评价答案及解析
- 农发行怀化市溆浦县2025秋招群面案例总结模板
- 2025年燃气职业技能鉴定考试历年机考真题集及参考答案详解(考试直接用)
- 2025年精神疾病的药物治疗选择题答案及解析
- 2025年健康教育与健康促进策略测试题答案及解析
- 监理考试题库及答案
- 家禽生产考试题目及答案
- 农发行抚顺市清原满族自治县2025秋招英文面试题库及高分回答
- 国家事业单位招聘2025求是杂志社招聘高校毕业生拟聘用人员笔试历年参考题库附带答案详解
- 天然气环保治理规程
- 危险方法危害公共安全罪认定标准研究
- 我国养老状况课件
- 心脏支架术后康复课件
- 2025年体育产业成本控制与赛事运营研究报告
- 能源问题面试题库及答案
- 国庆期间保安安全培训课件
- 2025年征兵心理测试题库及答案
- 监控设备迁移合同协议书
- 《老年服务礼仪与沟通技巧》全套教学课件
- 工程试验检测知识培训课件
- 2025年低碳节能减排知识竞赛题库(含答案)
评论
0/150
提交评论