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、執行存儲過程
2、填寫輸入參數
3、檢視查詢結果
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進行步進或者過程進,進行調試,調試時把滑鼠放到變量上即可檢視變量的值