SQL SERVER資料庫開發之預存程序的應用

來源:互聯網
上載者:User

一、建立預存程序

  和資料表一樣,在使用之前我們需要建立預存程序,它的簡明文法是:

 

CREATE PROC 預存程序名稱
    [參數列表(多個以“,”分隔)]
AS
SQL 語句

 例如

CREATE PROC upGetUserName
@intUserId        INT,
@ostrUserName NVARCHAR(20) OUTPUT                -- 要輸出的參數
AS
BEGIN
        -- 將uName的值賦給 @ostrUserName 變數,即要輸出的參數
        SELECT @ostrUserName=uName FROM uUser WHERE uId=@intUserId
END

其中 CREATE PROC 語句(完整語句為CREATE PROCEDURE)的意思就是告訴SQL SERVER,現在需要建立一個預存程序,upGetUserName 就是預存程序名稱,@intUserId 和 @ostrUserName 分別是該預存程序的兩個參數,注意,在SQL SERVER中,所有使用者定義的變數都以“@”開頭,OUTPUT關鍵字表示這個參數是用來輸出的,AS之後就是預存程序內容了。只要將以上代碼在“查詢分析器”裡執行一次,SQL SERVER就會在當前資料庫中建立一個名為“upGetUserName”的預存程序。你可以開啟“企業管理器”,選擇當前操作的資料庫,然後在左邊的樹型列表中選擇“預存程序”,此時就可以在右邊的列表中看到你剛剛建立的預存程序了(如果沒有,重新整理一下即可)。

三、預存程序的實際應用

  使用者登入在ASP項目中經常會使用到,相信很多朋友也都做過類似的系統,但使用預存程序來做驗證朋友可能不多,那麼我們就以它來做例子,寫一個簡單的使用者登入驗證的預存程序。

CREATE PROC upUserLogin
@strLoginName        NVARCHAR(20),
@strLoginPwd        NVARCHAR(20),
@blnReturn                BIT OUTPUT
AS
-- 定義一個臨時用來儲存密碼的變數
DECLARE @strPwd NVARCHAR(20)
BEGIN
        -- 從表中查詢目前使用者的密碼,賦值給 @strPwd 變數,下面要對他進行比較
        SELECT @strPwd=uLoginPwd FROM uUser WHERE uLoginName=@strLoginName

        IF @strLoginPwd = @strPwd
                BEGIN
                        SET @blnReturn = 1
                        -- 更新使用者最後登入時間
                        UPDATE uUser SET uLastLogin=GETDATE() WHERE uLoginName=@strLoginName
                END
        ELSE
                SET @blnReturn = 0
END
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.