我正在尝试运行一个返回单个整数值的存储过程,但我不知道哪里出了问题。 根据我所读的内容,以下代码应该可以工作,但是它并没有运行成功,我看不出错误在哪里。
这是我的存储过程:
ALTER PROCEDURE [dbo].[getDDNTempID]
AS
BEGIN
declare @tempID int
select top 1 @tempID = tempID from tblDDNHdr order by tempID asc
if @tempID is null
return 0
else
return @tempID
END
这是我尝试获取返回值的代码:
在这里,我尝试获取返回值的代码:
using (SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["test"].ConnectionString))
{
SqlCommand cmd = new SqlCommand("getDDNTempID", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Connection.Open();
Int32 tempID = (Int32)cmd.ExecuteScalar();
if (tempID == 0) { tempID = -1; }
return tempID;
}
当调用此过程时,我会得到一个NullReferenceException异常,并且给出错误的行是:
Int32 tempID = (Int32)cmd.ExecuteScalar();
我希望你们能给予任何有关IT技术的指导。
谢谢。