[英]Passing parameters for stored procedure
我有這個存儲過程:
CREATE PROCEDURE [Test]
(@ID INT,
@month VARCHAR(10),
@Low INT,
@standard FLOAT = 0)
AS
IF EXISTS (SELECT 1 FROM [Table1]
WHERE ID = @ID AND month = @month
AND TYPE = 'S' AND TYPEID = @Low)
BEGIN
UPDATE [Table1]
SET Add = @standard
WHERE ID = @ID AND month = @month
AND TYPE = 'S' AND TYPEID = @Low
END
ELSE
BEGIN
INSERT INTO [Table1] (ID, month, Add, TYPE, TYPEID)
VALUES (@ID, @month, @standard, 'S', @Low)
END
GO
這是缺少三月日期的表格
ID Month Add Type TypeID
---------------------------------------
333 feb 4 S 111
333 April 4 S 111
因此,我認為通過刷新存儲過程,該過程將在三月份進行。
但是當我使用執行程序時
Use [DB1]
GO
DECLARE @RV int
DECLARE @ID int
DECLARE @month varchar(10)
DECLARE @Low int
DECLARE @Add int
DECLARE @standard float
EXECUTE @RV = [Test]
@ID int,
@month varchar(10),
@Low int,
@Add int,
@standard float
GO
我懂了
ID Month Add Type TypeID
-----------------------------------------------
333 feb 4 S 111
333 April 4 S 111
NULL NULL NULL S NULL
雖然我在找
ID Month Add Type TypeID
------------------------------------------------
333 feb 4 S 111
333 April 4 S 111
333 Mar 4 S 111
我假設我沒有正確傳遞參數或其他東西。 有人可以建議嗎? 謝謝
您是在聲明要傳遞給存儲過程的參數,但沒有在任何地方分配它們的值,因此該過程沒有任何用處。
您需要將執行語句更改為以下內容:
Use [DB1]
GO
DECLARE @RV int = 0;
DECLARE @ID int = 333;
DECLARE @month varchar(10) = 'Mar';
DECLARE @Low int = 111;
DECLARE @Add int = 4;
DECLARE @standard float = 4;
EXECUTE @RV = [Test]
@ID = @ID,
@month = @month,
@Low = @Low,
@Add = @Add,
@standard = @standard;
GO
用要使用的任何值替換0和1.0。
此外, month
是表中的字符串列,但您要將INT
傳遞給過程。 您需要更改@month
參數以匹配表列的數據類型。
(在您編輯后刪除)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.