溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

SQLServer中怎么創(chuàng)建存儲過程

發(fā)布時間:2021-07-26 16:59:56 來源:億速云 閱讀:316 作者:Leah 欄目:數(shù)據(jù)庫

這篇文章給大家介紹SQLServer中怎么創(chuàng)建存儲過程,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

打開SQL Server 2005的管理工具,選中需要創(chuàng)建存儲過程的數(shù)據(jù)庫,找到“可編程性”,展開后可以看到“存儲過程”。右鍵點擊它,選擇“新建存儲過程”,右側(cè)的編輯窗口打開了,里面裝著微軟自動生成的SQL Server創(chuàng)建存儲過程的語句。

將存儲過程的名字,參數(shù),操作語句寫好后,點擊語法分析,沒有錯誤就直接“F5”運行就好了,存儲過程創(chuàng)建完畢,以下是一個基本的存儲過程的代碼:

 CREATE PROCEDURE Get_Data  (   @Dealer_ID VARCHAR(<strong>50</strong>)   )   AS  SELECT * FROM myData WHERE Dealer_ID = @Dealer_ID

點擊查看實際例子

既然創(chuàng)建存儲過程已經(jīng)會了,那么修改還會難嗎?顯然不會。修改存儲過程也是相當(dāng)?shù)娜菀?。首先,刷新?dāng)前數(shù)據(jù)庫的存儲過程列表,這時就能看到你剛創(chuàng)建的存儲過程的名字了,右鍵點擊它,選擇修改,右側(cè)又打開了一個編輯窗口,裝著的就是修改存儲過程的代碼(如下)

 ALTER PROCEDURE [dbo].[Get_Data]  (   @Dealer_ID VARCHAR(<strong>50</strong>)   )   AS  SELECT * FROM myData WHERE Dealer_ID = @Dealer_ID

簡單的修改下吧,代碼如下

ALTER PROCEDURE [dbo].[Get_Data]  (   @Dealer_ID VARCHAR(<strong>50</strong>),  @Period VARCHAR(<strong>20</strong>)  )   AS   SELECT * FROM myData WHERE Dealer_ID = @Dealer_ID AND Period = @Period

F5 成功執(zhí)行,修改存儲過程完成。

開始寫了一個存儲過程,用來實現(xiàn)數(shù)據(jù)的插入操作,說白了就是添加數(shù)據(jù)。這個存儲過程的代碼如下:

 CREATE PROCEDURE PROC_INSERT_DATA_ID @DealerID varchar(<strong>50</strong>) AS BEGIN 5   DECLARE @COUNT INT    SET @COUNT = (SELECT COUNT(*) FROM myDATA_Details WHERE DealerID = @DealerID)   IF (@COUNT><strong>0</strong>)     BEGIN      DELETE FROM myDATA_Details WHERE DealerID = @DealerID      INSERT INTO myDATA_Details (DealerID) VALUES (@DealerID)     END    ELSE     BEGIN      INSERT INTO myDATA_Details (DealerID) VALUES (@DealerID)     END   END --實際例子:http://hovertree.com/hovertreescj/sql/p_hovertreescj_urls_add.htm

F5一下,創(chuàng)建成功,調(diào)用它插入數(shù)據(jù),OK,沒問題插入成功,達(dá)到了預(yù)期的目的

用于更新數(shù)據(jù),代碼如下:

CREATE PROCEDURE PROC_INSERT_DATA_DETAIL   @DealerID varchar(<strong>50</strong>),    @FieldName varchar(<strong>2000</strong>),   @FieldValue varchar(<strong>2000</strong>)  AS  BEGIN   DECLARE @Count INT   SET @Count = (SELECT COUNT(*) FROM myDATA_Details WHERE DealerID = @DealerID)   IF (@COUNT><strong>0</strong>)    BEGIN     UPDATE myDATA_Details SET DealValue = @FieldValue WHERE DealerID = @DealerID    END   ELSE    BEGIN     INSERT INTO myDATA_Details (DealerID) VALUES (@DealerID)    END  END

或者:

修改后的代碼

 ALTER PROCEDURE PROC_INSERT_DATA_DETAIL   @DealerID varchar(<strong>50</strong>),    @FieldName varchar(<strong>2000</strong>),   @FieldValue varchar(<strong>2000</strong>)  AS  BEGIN   DECLARE @Count INT   DECLARE @StrSQL VARCHAR(<strong>2000</strong>)   SET @Count = (SELECT COUNT(*) FROM myDATA_Details WHERE DealerID = @DealerID)   IF (@COUNT><strong>0</strong>)    BEGIN     SET @StrSQL = 'UPDATE myDATA_Details SET '+ @FieldName + ' = ''' +@FieldValue + ''' WHERE DealerID = '+ @DealerID     EXEC(@StrSQL)    END   ELSE    BEGIN     INSERT INTO myDATA_Details (DealerID) VALUES (@DealerID)     SET @StrSQL = 'UPDATE myDATA_Details SET '+ @FieldName + ' = ''' +@FieldValue + ''' WHERE DealerID = '+ @DealerID     EXEC(@StrSQL)    END  END

關(guān)于SQLServer中怎么創(chuàng)建存儲過程就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI