程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 詳解SQLServer存儲過程(1)

詳解SQLServer存儲過程(1)

編輯:關於SqlServer

     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 ]
    [ { @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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved