天天看點

sqlserver存儲過程入門sqlserver存儲過程入門

sqlserver存儲過程入門

1. 輸入/輸出參數定義

@object_name varchar(50)  //定義一個varchar類型的輸入參數
@object_index int
@isUpdate int  =0  output //定義一個輸出參數
           

2.遊标使用步驟

1、定義遊标
DECLARE cur_objsName CURSOR for select name from tb_user;
2、打開遊标
OPEN cur_objsName;
3、提取遊标資料,進行業務處理
while @@fetch_status = 0   --如果上一次操作成功則繼續循環  
	begin
		update tb_user set calss='三年級5班' 	
		FETCH  NEXT FROM cur_objsName INTO 	
	end
4、關閉遊标
CLOSE cur_objsName;
5、釋放遊标
deallocate cur_objsName;
           

3.簡單示例

生産環境中會需要對軟體的版本進行更新,會相應的更新資料庫。當老版本軟體退役,新版本軟體上線時。會根據資料表結構的更新來進行資料遷移。
示例:根據輸入對象名稱,和列名,判斷表對象結構是否進行了更新
set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:		<Author,,Name>
-- Create date: <Create Date,,>
-- Description:	判斷表對象結構是否進行了更新
-- =============================================
alter PROCEDURE [dbo].[getIsUpdate]
	@object_name varchar(50),
	@contrast_column_name varchar(50),
	@isUpdate int  =0  output           -- 1= 是, 0=否
AS 
BEGIN
	-----------定義遊标----------------
	DECLARE cur_objsName CURSOR for select name from sys.all_columns where object_id = object_id(@object_name);
	declare @column_name varchar(50)  
-----------打開遊标----------------
	OPEN cur_objsName;
-----------------從遊标裡取出資料指派到我們剛才聲明的變量中(移動遊标指向到第一條資料,提取第一條資料存放在變量中)    
	FETCH NEXT FROM cur_objsName INTO @column_name   
--判斷遊标的狀态    
-- 0 fetch語句成功        
---1 fetch語句失敗或此行不在結果集中        
---2 被提取的行不存在  
	while @@fetch_status = 0   --如果上一次操作成功則繼續循環  
		begin
			if @[email protected]_name
				set @isUpdate =1
			FETCH  NEXT FROM cur_objsName INTO @column_name	
		end
END
-----------關閉遊标----------------
	CLOSE cur_objsName;
-----------釋放遊标----------------
	deallocate cur_objsName;
           

3.1SQLserver2005企業管理器中執行存儲過程

1、執行存儲過程

sqlserver存儲過程入門sqlserver存儲過程入門

2、填寫輸入參數

sqlserver存儲過程入門sqlserver存儲過程入門

3、檢視查詢結果

sqlserver存儲過程入門sqlserver存儲過程入門

4.powerbuilder中調用存儲過程

int returnValue
Declare stu_getIsUpdate Procedure For getIsUpdate // 定義過程調用
@object_name='tb_user',  @contrast_column_name='faction',   
@isUpdate=0 output;
Execute stu_getIsUpdate ;// 執行過程,這裡是不需要其他參數的

If SQLCA.SQLCode <> 0 Then // 調用過程出現錯誤處理
	messagebox('提示','資料庫更新時出現錯誤:getIsUpdate........')
	return
End If
Fetch stu_getIsUpdate Into :returnValue;
// 擷取出參值,也就是OUT的變量,如果沒有out類型的變量,這句也就不需要了
If SQLCA.SQLCode <> 0 Then // 擷取資料出現錯誤處理
	messagebox('提示','資料庫更新時出現錯誤:getIsUpdate........')
	return
End If
Close stu_getIsUpdate ;	
if  returnValue=0 then
	//根據存儲過程傳回值,來執行相應業務邏輯
end if
           

5.使用Visual Studio 進行存儲過程的調試

1、打開visual studio 2013,單擊“視圖”,選擇“伺服器資料總管”。

2、右鍵單擊“資料連接配接”,選擇“添加連接配接”

3、在彈出的視窗中選擇“Microsoft SQL Server”或者“Microsoft SQL Server資料庫檔案”

4、在第三步基礎上進行配置,這一步根據第三步選擇選項不同,進行配置的内容不同,但都比較簡單,不做描述。

5、添加連接配接完成之後,點選“存儲過程”,選擇你要調試的存儲過程,右鍵單擊,選擇“執行”,在彈出視窗中輸入相應參數(如果有的話)

6、在打開的頁籤視窗中點選綠色按鈕右邊的下拉按鈕,選擇“使用調試器執行”,開始調試。

7、調試時,可以按F11或者F10進行步進或者過程進,進行調試,調試時把滑鼠放到變量上即可檢視變量的值

簡單示例

sqlserver存儲過程入門sqlserver存儲過程入門

6.歡迎關注微信公衆号

sqlserver存儲過程入門sqlserver存儲過程入門

繼續閱讀