[英]Stored procedure returns null as output parameter
我有stored procedure
,它在 MS SQL 管理工作室中很好用。
當我嘗試在 VS 行中使用它時返回正常,但輸出參數的值為NULL 。
SqlCommand cmd = new SqlCommand("proc_name", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("@p_SomeVal", SqlDbType.Int));
cmd.Parameters["@p_SomeVal"].Direction = ParameterDirection.Output;
rdr = cmd.ExecuteReader();
//...process rows...
if (cmd.Parameters["@p_SomeVal"].Value != null)
SomeVal = (int)cmd.Parameters["@p_SomeVal"].Value;
cmd.ExecuteNonQuery(); 有同樣的結果。
USE [db_name]
GO
DECLARE @return_value int,
@p_SomeValue int
EXEC @return_value = [dbo].[Proc_name]
@p_InputVal = N'aa',
@p_SomeValue = @p_SomeValue OUTPUT
SELECT @p_SomeValue as N'p_SomeValue'
SELECT 'Return Value' = @return_value
GO
SqlCommand cmd = new SqlCommand("proc_name", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("@p_SomeVal", SqlDbType.Int));
cmd.Parameters["@p_SomeVal"].Direction = ParameterDirection.Output;
rdr = cmd.ExecuteReader();
//...process rows...
rdr.Close();
if (cmd.Parameters["@p_SomeVal"].Value != null)
SomeVal = (int)cmd.Parameters["@p_SomeVal"].Value;
處理行后,我添加了rdr.Close();
並且工作正常。
Salaam,您可以檢查輸出是否為空並像這樣進行轉換。
returnedSQLParameter.Value != DBNull.Value? (int)returnedSQLParameter.Value : 0;
因為當輸出從存儲過程發送NULL
時它返回DBNull.value
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.