Sql Server的存儲過程是一個被命名的存儲在伺服器上的Transacation-Sql語句集合,是封裝重覆性工作的一種方法,它支持用戶聲明的變數、條件執行和其他強大的編程功能。 存儲過程相對於其他的資料庫訪問方法有以下的優點: (1)重覆使用。存儲過程可以重覆使用,從而可以減少資料庫開發人員的
Sql Server的存儲過程是一個被命名的存儲在伺服器上的Transacation-Sql語句集合,是封裝重覆性工作的一種方法,它支持用戶聲明的變數、條件執行和其他強大的編程功能。
存儲過程相對於其他的資料庫訪問方法有以下的優點:
(1)重覆使用。存儲過程可以重覆使用,從而可以減少資料庫開發人員的工作量。
(2)提高性能。存儲過程在創建的時候就進行了編譯,將來使用的時候不用再重新編譯。一般的SQL語句每執行一次就需要編譯一次,所以使用存儲過程提高了效率。
(3)減少網路流量。存儲過程位於伺服器上,調用的時候只需要傳遞存儲過程的名稱以及參數就可以了,因此降低了網路傳輸的數據量。
(4)安全性。參數化的存儲過程可以防止SQL註入式的攻擊,而且可以將Grant、Deny以及Revoke許可權應用於存儲過程。
存儲過程一共分為了三類:用戶定義的存儲過程、擴展存儲過程以及系統存儲過程。
其中,用戶定義的存儲過程又分為Transaction-SQL和CLR兩種類型。
Transaction-SQL 存儲過程是指保存的Transaction-SQL語句集合,可以接受和返回用戶提供的參數。
CLR存儲過程是指對.Net Framework公共語言運行時(CLR)方法的引用,可以接受和返回用戶提供的參數。他們在.Net Framework程式集中是作為類的公共靜態方法實現的。(本文就不作介紹了)
創建存儲過程的語句如下:
以下為引用的內容: 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