《数据库》课件实验9-事务_第1页
《数据库》课件实验9-事务_第2页
《数据库》课件实验9-事务_第3页
《数据库》课件实验9-事务_第4页
《数据库》课件实验9-事务_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

实验:事务1一、实验目的与任务目的:旨在训练学生能创建带有事务的存储过程及了解事务的并发情况。任务:根据需求,写出满足条件的存储过程。任务1:在SchoolInfo数据库中执行如下语句:createtableTicket( TicketInfovarchar(20)primarykey, TicketLeaveNumint)insertintoTicketvalues('G0001',10)任务2:测试事务执行情况。createprocprcInsertStudentasbegintrybegintransactionINSERTINTOStudentVALUES('A00010',‘Andy',21,'男','Nanjing',90,1)INSERTINTOStudentVALUES(‘A00011’,‘mary’,21,'女','Nanjing',150,1)committransactionendtrybegincatch rollbacktransactionendcatch以上事务执行时,A00011号记录的成绩值超出了范围,编译器报错,此时会被Catch语句捕获,回滚事务,数据库中两条记录都不能插入。可将A00011号记录的成绩改为90,重新测试存储过程,两条语句同时被成功插入数据库。任务3:创建事务,假设给定学号的学生将从原系转入给定的系,则相应的系总人数将发生变化,如果两系相差人数小于10,则允许该生转系,否则回滚事务。假设系表Department(DepID,DepName,Total)答案:createprocprcTransfer@StuIDchar(10),@DepNamevarchar(20)asbegintryifexists(select*fromStudentwhereStuID=@StuID)ifexists(select*fromDepartmentwhereDepName=@DepName)beginbegintransactiondeclare@OriginDepIDintselect@OriginDepID=DepIDfromStudentwhereStuID=@StuIDdeclare@NewDepIDintselect@NewDepID=DepIDfromDepartmentwhereDepName=@DepNameupdateStudentsetDepID=@NewDepIDwhereStuID=@StuIDdeclare@OriginTotalintdeclare@NewTotalintupdateDepartmentsetTotal=Total-1whereDepID=@OriginDepIDupdateDepartmentsetTotal=Total+1whereDepID=@NewDepIDselect@OriginTotal=TotalfromDepartmentwhereDepID=@OriginDepIDselect@NewTotal=TotalfromDepartmentwhereDepID=@NewDepIDif(@NewTotal-@OriginTotal>=-10and@NewTotal-@OriginTotal<=10)commitTransactionelseRollbackTransactionendelseprint'DepName不存在'elseprint'StuID不存在'endtrybegincatchRollbackTransactionendcatch执行:execprcTransfer'A00001','math'任务4:SC表和Department表需要用下面的事务来更新:事务1:UPDATESCSETScore=Score+1WHEREStuID=‘A00001’andCourseID=1UPDATESCSETScore=Score-1WHEREStuID=‘A00001’andCourseID=2事务2:INSERTINTOSTUDENTVALUES('A00004','mary',21,'男','Nanjing',90,1)UPDATEDepartmentSETTotal=Total+1WHEREDepID=1所有更新应一起来做。对于Department,如果Total值大于100,由第二个事务所产生的改变必须被回滚,而由第一个事务产生的改变是允许的。答案:beginTransactionUPDATESCSETScore=Score+1WHEREStuID='A00001'andCourseID=1UPDATESCSETScore=Score-1WHEREStuID='A00001'andCourseID=2saveTransactiontrnTransaction1INSERTINTOSTUDENTVALUES('A00013','mary',21,'男','Nanjing',90,1)UPDATEDepartmentSETTotal=Total+1WHEREDepID=1if(selectTotalfromDepartmentwhereDepID=1)>100beginRollbackTransactiontrnTransaction1commitTransactionendelsecommitTransaction任务5:在编译器中使两个事务同时执行,查看数据库情况CREATEPROCprcSellTicket@TicketInfovarchar(20),--车次信息@TicketNumint--售出张数ASBegintranDeclare@TicketLeaveNumintSelect@TicketLeaveNum=TicketLeaveNumfromTicketWhereTicketInfo=@TicketInfo--①waitfordelay'00:00:20.005'UpdateTicketsetTicketLeaveNum=@TicketLeaveNum-@TicketNumWhereTicketInfo=@TicketInfo--②If(@TicketLeaveNum<@TicketNum) beginrollbacktranprint'售票失败'endElsebeginCommittranprint'售票成功'end以上程序如果多个窗口同时执行,数据会产生错误吗?如何修改以上程序?答案:会产生错误。使用锁或设置事务的隔离级别。--加锁alterPROCprcSellTicket@TicketInfovarchar(20),--车次信息@TicketNumint--售出张数ASbegintry ifexists(select*fromTicketwhereTicketInfo=@TicketInfo) begin Begintran selectTicketLeaveNumfromTicketwith(tablockx) Declare@TicketLeaveNumint Select@TicketLeaveNum=TicketLeaveNumfromTicket WhereTicketInfo=@TicketInfo--① waitfordelay'00:00:20.000' UpdateTicketsetTicketLeaveNum=@TicketLeaveNum-@TicketNum WhereTicketInfo=@TicketInfo--② If(@TicketLeaveNum<@TicketNum) begin rollbacktran print'售票失败' end Else begin Committran print'售票成功' end end else print'信息不存在'endtrybegincatch rollbacktran print'服务器忙,售票失败'endcatch--设置事务隔离级别alterPROCprcSellTicket@TicketInfovarchar(20),--车次信息@TicketNumint--售出张数ASbegintry ifexists(select*fromTicketwhereTicketInfo=@TicketInfo) begin settransactionisolationlevelrepeatableread Begintran Declare@TicketLeaveNumint Select@TicketLeaveNum=TicketLeaveNumfromTicket WhereTicketInfo=@TicketInfo--① waitfordelay'00:00:20.000' UpdateTicketsetTicketLeaveNum=@TicketLeaveNum-@TicketNum WhereTicketInfo=@TicketInfo--② If(@TicketLeaveNum<@TicketNum) begin rollbacktran print'售票失败' end Else begin Committran print'售票成功' end end else print'信息不存在'endtrybegincatch rollbacktran print'服务器忙,售票失败'endcatch三、内容与要求课题名称——事务1(一)课题内容

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论