帶輸入?yún)?shù)存儲過程_第1頁
帶輸入?yún)?shù)存儲過程_第2頁
帶輸入?yún)?shù)存儲過程_第3頁
帶輸入?yún)?shù)存儲過程_第4頁
帶輸入?yún)?shù)存儲過程_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、帶輸入?yún)?shù)存儲過程創(chuàng)建帶參數(shù)的存儲過程存儲過程的參數(shù)分兩種:輸入?yún)?shù)輸出參數(shù)輸入?yún)?shù):用于向存儲過程傳入值,類似C語言的按值傳遞;輸出參數(shù):用于在調(diào)用存儲過程后,返回結(jié)果,類似C語言的按引用傳遞;帶輸入?yún)?shù)的存儲過程通過參數(shù)名傳遞值用parameter=value格式在EXEC語句中指定參數(shù),稱為通過參數(shù)名傳遞值,在通過參數(shù)名傳遞值時,參數(shù)可以以任何順序指定,可以忽略,允許空值和有默認的參數(shù)存在。帶輸入?yún)?shù)的存儲過程在以下情況下使用存儲過程中定義的默認參數(shù)值: 在執(zhí)行存儲過程時沒有給參數(shù)指定值指定default關(guān)鍵字作為參數(shù)的值帶輸入?yún)?shù)的存儲過程問題:請創(chuàng)建存儲過程,查看本次考試平均分以及未

2、通過考試的學(xué)員名單。(由于每次考試的難易程度不一樣,每次 筆試和機試的及格線可能隨時變化(不再是60分),這導(dǎo)致考試的評判結(jié)果也相應(yīng)變化。)分析:在述存儲過程添加2個輸入?yún)?shù):writtenPass 筆試及格線 labPass 機試及格線帶輸入?yún)?shù)的存儲過程CREATE PROCEDURE proc_stu1 writtenPass int, /*輸入?yún)?shù):筆試及格線*/ labPass int /*輸入?yún)?shù):機試及格線*/ AS print 參加本次考試沒有通過的學(xué)員: SELECT stuName, stuInfo.stuNo, writtenExam, labExam From stuI

3、nfo /*查詢沒有通過考試的學(xué)員*/ INNER JOIN stuMarks ON stuInfo.stuNo=stuMarks.stuNo WHERE writtenExamwrittenPass OR labExamlabPass 帶輸入?yún)?shù)的存儲過程調(diào)用帶參數(shù)的存儲過程假定本次考試機試偏難,機試的及格線定為55分,筆試及格線定為60分調(diào)用過程EXEC proc_stu1 60,55-或這樣調(diào)用:EXEC proc_stu1 labPass=55,writtenPass=60輸入?yún)?shù)的默認值帶參數(shù)的存儲過程確實比較方便,調(diào)用者可根據(jù)試卷的難易度,隨時修改每次考試的及格線問題:如果試卷的難

4、易程度合適,則調(diào)用者還是必須如此調(diào)用: EXEC proc_stu 60,60,比較麻煩,這樣調(diào)用就比較合理:EXEC proc_stu1 55筆試及格線55分,機試及格線默認為60分 EXEC proc_stu1筆試和機試及格線都默認為標準的60分輸入?yún)?shù)的默認值CREATE PROCEDURE proc_stu2 writtenPass int=60, /*筆試及格線:默認為60分*/ labPass int=60 /*機試及格線:默認為60分*/ AS print 參加本次考試沒有通過的學(xué)員: SELECT stuName,stuInfo.stuNo,writtenExam,LabExa

5、m FROM stuInfo INNER JOIN stuMarks ON /*查詢沒有通過考試的學(xué)員*/ stuInfo.stuNo=stuMarks.stuNo WHERE writtenExamwrittenPass OR LabExamlabPass 輸入?yún)?shù)的默認值調(diào)用帶參數(shù)默認值的存儲過程EXEC proc_stu2 -都采用默認值 EXEC proc_stu2 64 -機試采用默認值 EXEC proc_stu2 60,55 -都不采用默認值 -錯誤的調(diào)用方式:希望筆試采用默認值,機試及格線55分EXEC proc_stu2 ,55-正確的調(diào)用方式:EXEC proc_stu2 labPass=55 使用輸入?yún)?shù)執(zhí)行存儲過程通過定位傳遞參數(shù)只進行值的傳遞(沒有引用傳遞參數(shù))稱為通

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論