




下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
實驗:事務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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 工業自動化技術的新進展與應用案例分析
- 工業領域環保技術的前沿與發展
- 工業設計與環境保護的關系
- 工作中的口頭與書面溝通技巧
- 工作場所靈活性與效率關系探討
- 工作場所的綠色環保理念與實踐
- 工作模式變革下的人才培養計劃
- 工程數學中的建模與計算方法
- 工程機械中焊接結構的耐久性優化
- 工程建筑中的綠色節能技術應用研究
- 《常州紅梅公園》課件
- 軟件正版化工作培訓
- 《限額以下小型工程施工安全管理辦法(試行)》知識培訓
- 廣西申論真題2021年(B卷)
- 國家職業技術技能標準 4-04-05-05 人工智能訓練師 人社廳發202181號
- GB/T 44442-2024智能制造遠程運維系統評價指標體系
- 國開建筑工程技術實踐
- 延長石油招聘筆試題庫
- 廣東省深圳市龍崗區多校聯考2024年統編版小升初考試語文試卷(解析版)
- 2023年北京第二次高中學業水平合格考化學試卷真題(含答案詳解)
- 02R111小型立、臥式油罐圖集
評論
0/150
提交評論