什麼是存儲過程
如果你接觸過其他的編程語言,那麼就好理解了,存儲過程就像是方法一樣。
竟然他是方法那麼他就有類似的方法名,方法要傳遞的變量和返回結果,所以存儲過程有存儲過程名有存儲過程參數也有返回值。
存儲過程的優點:
存儲過程的能力大大增強了SQL語言的功能和靈活性。
1.可保證數據的安全性和完整性。
2.通過存儲過程可以使沒有權限的用戶在控制之下間接地存取數據庫,從而保證數據的安全。
3.通過存儲過程可以使相關的動作在一起發生,從而可以維護數據庫的完整性。
4.在運行存儲過程前,數據庫已對其進行了語法和句法分析,並給出了優化執行方案。這種已經編譯好的過程5.可極大地改善SQL語句的性能。
6.可以降低網絡的通信量。
7.使體現企業規則的運算程序放入數據庫服務器中,以便 集中控制。
存儲過程可以分為系統存儲過程、擴展存儲過程和用戶自定義的存儲過程
系統存儲過程
我們先來看一下系統存儲過程,系統存儲過程由系統定義,主要存放在MASTER數據庫中,名稱以"SP"開頭或以"XP"開頭。盡管這些系統存儲過程在MASTER數據庫中,
但我們在其他數據庫還是可以調用系統存儲過程。有一些系統存儲過程會在創建新的數據庫的時候被自動創建在當前數據庫中。
常用系統存儲過程有:
代碼如下:
存儲過程語法:
在創建一個存儲過程前,先來說一下存儲過程的命名,看到好幾篇講存儲過程的文章都喜歡在創建存儲過程的時候加一個前綴,養成在存儲過程名前加前綴的習慣很重要,雖然這只是一件很小的事情,但是往往小細節決定大成敗。看到有的人喜歡這樣加前綴,例如proc_名字。也看到這加樣前綴usp_名字。前一種proc是procedure的簡寫,後一種sup意思是user procedure。我比較喜歡第一種,那麼下面所有的存儲過程名都以第一種來寫。至於名字的寫法采用駱駝命名法。
創建存儲過程的語法如下:
代碼如下:
@參數1 [數據類型]=[默認值] [OUTPUT]
@參數2 [數據類型]=[默認值] [OUTPUT]
AS
SQL語句
EXEC 過程名[參數]
使用存儲過程實例:
1.不帶參數
代碼如下:
exec proc_select_officeinfo--(調用存儲過程)
2.帶輸入參數
代碼如下:
exec procedure_proc_GetoffinfoById 2--(存儲過程名稱之後,空格加上參數,多個參數中間以逗號分隔)
注:參數賦值是,第一個參數可以不寫參數名稱,後面傳入參數,需要明確傳入的是哪個參數名稱
3.帶輸入輸出參數
代碼如下:
4.帶返回值的
代碼如下:
declare @house varchar(20) --聲明一個變量,獲取存儲過程傳出來的值
exec @house=proc_office_info 2 --(調用存儲過程,用變量接收返回值)
--注:帶返回值的存儲過程只能為int類型的返回值
print @house