使用执行阅读器从SQL获取返回值

Jac*_*hor 3 c# sql sql-server stored-procedures

所以我在SQL Server中有这个存储过程,里面有这部分SQL

... part of store procedure...
IF @@ERROR = 0 --AND @@ROWCOUNT = 1
BEGIN
     .. dO STUFF 
     SELECT * FROM MyTable
    RETURN 0
END
ELSE
BEGIN
    RAISERROR('Something went wrong :-(', 16, 1)
    RETURN -1
END

END
Run Code Online (Sandbox Code Playgroud)

在我的C#代码中,获取数据的方式是这样的

//Sql param used to get the return value from the store procedure
SqlParameter returnValueParam = command.Parameters.Add("@return_value", SqlDbType.Int);
returnValueParam.Direction = ParameterDirection.ReturnValue;
using (var reader = command.ExecuteReader(CommandBehavior.CloseConnection))
{
 while (reader.Read())
 {
  SpRetrunValue.EmailAddress = DBNulls.DBNullToString(reader["Email"], string.Empty);
... More stuff
  }
   reader.NextResult();
   SpRetrunValue.ExternalData = new List<ExternalData>();
   var ExtData = new ExternalData();
  while (reader.Read())
  {
   ExtData.Id = DBNulls.DBNullToInteger(reader["ID"], 0);
   SpRetrunValue.ExternalData.Add(intExtData);
   }
   //get the return code on the SP 0 for success -1 for error
   SpRetrunValue.ResultCode = (int)returnValueParam.Value;
   }
Run Code Online (Sandbox Code Playgroud)

我遇到的问题是,如果与之配合使用,command.ExecuteNonQuery();则可以获得返回值。但是现在使用as不能得到返回值,但是可以得到结果集。这样无法获得返回值吗?我已经在stackoverflow上看到了这篇文章,但这需要我向存储过程添加另一个参数,我觉得这与仅返回上面的存储过程中的值的目的背道而驰。

小智 5

在尝试捕获Return值或OUTPUT参数之前,您必须完成所有行集的处理。声明SpRetrunValue.ResultCode = (int)returnValueParam.Value;后放置using

了解SQL Server返回码和输出参数

另外,这个帖子