您的位置: turnitin查重官网> 工程 >> 网络工程 >触发器SQLSever2005中利用触发器实现数据库完整性教学案例设计学士

触发器SQLSever2005中利用触发器实现数据库完整性教学案例设计学士

收藏本文 2024-01-29 点赞:7454 浏览:19747 作者:网友投稿原创标记本站原创

摘要:本文详细设计了SQL Sever 2005中利用触发器实现数据库完整性的教学案例,通过案例驱动的方式完成了数据库完整性的教学任务。实践表明,此教学方式能够弥补传统教学的不足,激发每位学生的学习兴趣和学习潜能,锻炼学生良好的职业规范道德、团队分工协作等素质,大大缩短教学情景与实际软件开发的差距,增强以实践能力培养为目标的应用型人才培养新模式,从而实现应用型人才的培养目标。
关键词:案例设计;教学改革;数据库完整性
1007-9599 (2012) 19-0000-02
数据库的完整性是指防止不合语义的即不正确、不相容的数据进入数据库。绝大部分RDBMS都支持使用触发器实现数据库的完整性。触发器(Trigger)是保证数据完整性的一种方法,是用户定义在基本表上的一类由事件驱动的特殊过程。它与表格紧密相连,可以看做是表格定义的一部分,当用户修改指定表中的数据时,触发器将会自动执行。触发器基于一个表创建,但是可以针对多个表进行操作,所以触发器常被用来实现复杂的商业规则。

1 案例描述

在银行的自动取款机系统中,有两个数据表:账户信息表(Bank)和交易信息表(Transinfo)。账户信息表(bank)中记录每个账户的cardID、账户的户主姓名customerName、该账户上目前的余额currentMoney。交易信息表(transinfo)中记录每一笔交易的时间transDate、交易的卡号cardID、交易的类型transType、交易的金额transMoney。
提出问题:现在余萧萧使用自动取款机系统取200元钱,如何编写程序使该自动取款机系统自动修改余萧萧的余额。

2 案例分析

当客户进行一项存款或取款操作时,会在交易信息表(Transinfo)上形成一个插入操作。可以利用这个插入操作的数据实现在账户信息表(Bank)中自动修改余萧萧的余额。

3 案例实现

根据案例要求,引导学生进行讨论并完成触发器的设计。具体参考操作步骤如下:
Step 1:根据案例要求和以前的知识积累,学生完成数据库、数据表的创建。
Step 2:根据案例描述,在交易信息表(Transinfo)上创建一个Insert类型的触发器trig_transInfo。代码如下:
Step 3:可以通过在交易信息表(Transinfo)中插入一条记录模拟用户的一次取款操作来查看触发器是否被激发执行了。现执行SQL语句:Insert Into TRANSINFO (cardID, transType, transMoney) values (‘10010001’,’支取’,200),可以在结果窗格中,看到消息“TRANSINFO中cardID为10010001的记录被修改了”。
Step 4:刷新账户信息表(bank)并查询该表中的数据,看到余萧萧的账户余额被修改成了800。

4 课堂总结

4.1 对触发器的理解。触发器是在对表进行插入、更新或删除操作时自动执行的存储过程,它是被定义在特定的表上,与某个表相关,不能直接调用,自动触发执行的一个事务[3]。4.2 触发器的分类。按触发器激活的时机不同,分为:后触发器:只有执行了insert、delete、update操作后,才激发的触发器。替代触发器:不执行命令所定义的insert、delete、update操作,而仅执行触发器中定义的代码。按引起触发的事件不同,分为:insert触发器:当被创建触发器的表上有Insert操作时该类型的触发器被触发并自动在内存里创建Inserted表,该表中保存了Insert操作时的数据副本。delete触发器:当被创建触发器的表上有Delete操作时该类型的触发器被触发并自动在内存里创建Deleted表,该表中保存了Delete操作时的数据副本。update触发器:当被创建触发器的表上有Updated操作时该类型的触发器被触发并自动在内存里创建Inserted表和Deleted表,Deleted表中保存了修改之前的数据副本,Inserted表中保存了修改后的数据副本。4.3 Inserted表和Deleted表的作用。触发器代码最强大的功能之一是能够比较纪录的新旧版本,其中最关键的是Inserted和Deleted这两个临时表。触发器被触发时,系统自动在内存中创建Deleted表或Inserted表,这两个表都是只读的,并且不允许修改,触发器执行完成后,这两个表都自动被删除。Inserted表临时保存了插入或更新后的记录行,可以从Inserted表中检查插入或更新后的数据是否满足业务需求,如果不满足,则向用户报告错误消息,并回滚插入操作。Deleted表临时保存了删除或更新前的记录行,可以从Deleted表中检查被删除或更新前的数据是否满足业务需求,如果不满足,则向用户报告错误消息,并回滚插入操作。

4.4 如何创建触发器。创建触发器的语法:

实践证明,通过案例能够把抽象的原理、概念等具体化,能够使学生清楚地认识到这些原理、概念在实际软件开发中的用处,激发了每位学生的学习兴趣和学习潜能。数据库系统原理课程教学中案例教学的应用,提升了学生的能力和质量,加强了学生理论联系实际的能力,培养了学生独立思考、发现问题、解决问题的能力,锻炼了学生良好的职业规范道德、团队分工协作等素质,加强了学生应用数据库技术进行系统设计与开发甚至科研的能

摘自:毕业论文任务书www.udooo.com

力,使学生能够独立地、创造性地进行学习[4]。训练和培养了双师型队伍的可持续发展,使得教师能够跟踪最新技术的发展动态,结合专业实际把新的教学方法和手段带进课堂,提高了教学效率和教学效果。增强了以实践能力培养为目标的应用型人才培养新模式,大大缩短教学情景与实际软件开发的差距,从而实现了应用型人才的培养目标。一系列改革的实施符合应用型教育的要求,对推进应用型人才培养有着非常重要的意义。
参考文献:
王珊,萨师煊.数据库系统概论[M],北京:高等教育出版社2006:151.
胡锦丽.数据库原理及应用案例教程[M],北京:北京大学出版社.2008:161-166.
[3]刘晓平.触发器在数据库中的应用.韶关学院学报[J].2007,28(3):35-38.
[4]张丽梅.案例教学法的研究与教学实践.黑龙江教育[J].2006(3):51-52.
基金项目:滨州学院2007年度教学研究项目,《基于案例教学的数据库教学改革的研究》项目编号:BZXYJYXM200738。2008年度校级重点课程《数据库系统原理》,项目编号:BZXYZDKC200904。

copyright 2003-2024 Copyright©2020 Powered by 网络信息技术有限公司 备案号: 粤2017400971号