詳解SQLServer 存儲過程

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 ] 
    [ { @parameter [ type_schema_name. ] data_type } 
        [ VARYING ] [ = default ] [ [ OUT [ PUT ] 
    ] [ ,n ] 
[ WITH <procedure_option> [ ,n ]
[ FOR REPLICATION ] 
AS { <sql_statement> [;][ n ] | <method_specifier> }
[;]
<procedure_option> ::= 
    [ ENCRYPTION ]
    [ RECOMPILE ]
    [ EXECUTE_AS_Clause ]

<sql_statement> ::= 
{ [ BEGIN ] statements [ END ] }

<method_specifier> ::=
EXTERNAL NAME assembly_name.class_name.method_name

 

     [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

轉載自:http://www.aspnetjia.com

相關文章
相關標籤/搜索