Sql Server的存儲過程是一個被命名的存儲在服務器上的Transacation-Sql語句集合,是封裝重複性工做的一種方法,它支持用戶聲明的變量、條件執行和其餘強大的編程功能。sql
存儲過程相對於其餘的數據庫訪問方法有如下的優勢:數據庫
(1)重複使用。存儲過程能夠重複使用,從而能夠減小數據庫開發人員的工做量。編程
(2)提升性能。存儲過程在建立的時候就進行了編譯,未來使用的時候不用再從新編譯。通常的SQL語句每執行一次就須要編譯一次,因此使用存儲過程提升了效率。安全
(3)減小網絡流量。存儲過程位於服務器上,調用的時候只須要傳遞存儲過程的名稱以及參數就能夠了,所以下降了網絡傳輸的數據量。服務器
(4)安全性。參數化的存儲過程能夠防止SQL注入式的攻擊,並且能夠將Grant、Deny以及Revoke權限應用於存儲過程。網絡
存儲過程一共分爲了三類:用戶定義的存儲過程、擴展存儲過程以及系統存儲過程。架構
其中,用戶定義的存儲過程又分爲Transaction-SQL和CLR兩種類型。性能
Transaction-SQL 存儲過程是指保存的Transaction-SQL語句集合,能夠接受和返回用戶提供的參數。spa
CLR存儲過程是指對.Net Framework公共語言運行時(CLR)方法的引用,能夠接受和返回用戶提供的參數。他們在.Net Framework程序集中是做爲類的公共靜態方法實現的。(本文就不做介紹了)ci
建立存儲過程的語句以下:
如下爲引用的內容: CREATE { PROC | PROCEDURE } [schema_name.] procedure_name [ ; number ] |
[schema_name]: 表明的是存儲過程所屬的架構的名稱
例如:
Create Schema yangyang8848
Go
Create Proc yangyang8848.AllGoods
As Select * From Master_Goods
Go
執行:Exec AllGoods 發生錯誤。
執行:Exec yangyang8848.AllGoods 正確執行。
[;Number]: 用於對同名過程進行分組的可選整數。使用一個 DROP PROCEDURE 語句可將這些分組過程一塊兒刪除。
例如:
Create Proc S1 ;1
AS
Select * From Master_Goods
Go
Create Proc S1 ;2
As
Select * From Master_Location
Go