SQLServer2005_存儲過程

SQLServer2005_存儲過程

ID:37512487

大小:62.00 KB

頁數(shù):10頁

時間:2019-05-24

SQLServer2005_存儲過程_第1頁
SQLServer2005_存儲過程_第2頁
SQLServer2005_存儲過程_第3頁
SQLServer2005_存儲過程_第4頁
SQLServer2005_存儲過程_第5頁
資源描述:

《SQLServer2005_存儲過程》由會員上傳分享,免費在線閱讀,更多相關內容在行業(yè)資料-天天文庫。

1、/**************存儲過程*******************************//*    是在數(shù)據(jù)庫服務器上創(chuàng)建、運行的一組sql語句的集合的過程程序通常只在首次運行時編譯后駐留高速緩存中,以后調用直接在高速緩存中獲取優(yōu)點:提高查詢性能,減少網(wǎng)絡流量編譯優(yōu)化執(zhí)行速度快加強安全性類型用戶定義的存儲過程系統(tǒng)存儲過程系統(tǒng)存儲過程以字符sp_開頭擴展存儲過程系統(tǒng)擴展存儲過程以字符sp_或xp_開頭*/--系統(tǒng)存儲過程   --通常返回0表示成功失敗為非0值execsp_databasesexecsp_helpfile--返回當前數(shù)據(jù)庫的文件信息--用戶定義的存

2、儲過程--創(chuàng)建--規(guī)則:--不能包含的sql語句create[defaulttriggerviewrulefunction]等----不帶參數(shù)的存儲過程createprocedureproc_empasselect*fromemp;--調用execdbo.proc_emp--帶輸入?yún)?shù)的存儲過程IFOBJECT_ID('dbo.proc_emp2','P')ISNOTNULLDROPPROCEDUREdbo.proc_emp2;GOCREATEPROCEDUREdbo.proc_emp2@namevarchar(20)='劉德華',--指定默認值@idint=107ASbeg

3、inif(@id>100)select*fromempwhereempName=@nameorempId=@idelseprint'編號必須大于100';end--調用方式execdbo.proc_emp2execdbo.proc_emp2'張無忌',44execdbo.proc_emp2@name='張無忌',@id=101--帶通配符輸入?yún)?shù)的存儲過程ifObject_id('dbo.proc_emp3','p')isnotnulldropprocdbo.proc_emp3gocreateprocproc_emp3@namevarchar(20)='張%'--指定默認值a

4、sselect*fromempwhereempNamelike@name;--調用execproc_emp3'%'execproc_emp3@name='劉%'execproc_emp3--使用輸出參數(shù)的存儲過程ifObject_id('dbo.proc_emp4','p')isnotnulldropprocdbo.proc_emp4gocreateproceduredbo.proc_emp4@maxintoutput,@namevarchar(20)outputasselecttop1@name=empName,@max=payfromemp4orderbypaydesc;

5、GO--調用declare@mint,@nvarchar(20)executedbo.proc_emp4@moutput,@noutprint'薪水最高的員工:'+@n+'薪水:'+cast(@masvarchar(5))--綜合例子:ifexists(select*fromsys.sysobjectswherename='bank')droptablebankGOcreatetablebank(customerNamevarchar(20),currentMoneydecimal(12,2)--當前余額)altertablebankaddconstraintCK_curre

6、ntMonaltereycheck(currentMoney>=1.00)GOinsertintobankvalues('張三',1000)insertintobankvalues('李四',1)GOCreateprocproc_bank@avarchar(20),@bvarchar(20),@mdecimal,@rintoutputasbegintransactionbegintryupdatebanksetcurrentMoney=currentMoney-@mwherecustomerName=@aupdatebanksetcurrentMoney=currentMon

7、ey+@mwherecustomerName=@bcommittransactionset@r=1endtrybegincatchrollbacktransactionset@r=0endcatch--調用declare@aintexecproc_bank'張三','李四',1000,@aoutputprint@aGo--withencryption--加密存儲過程的定義阻止返回存儲過程的定義文本createprocproc_emp5withencryptionasselect*fromemp;exec

當前文檔最多預覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學公式或PPT動畫的文件,查看預覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內容,確認文檔內容符合您的需求后進行下載,若出現(xiàn)內容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網(wǎng)絡波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。