Can you use cmd.ExecuteScalar when the sproc uses RETURN @value(sproc 使用 RETURN @value 时可以使用 cmd.ExecuteScalar)
问题描述
你会用吗
int blah = Convert.ToInt32(cmd.ExecuteScalar());
当 sproc 的最后一条语句执行时:
When the sproc's last statement does:
RETURN @value
只有这样,我才能让它工作:
I can only get it to work if it does:
选择@值
另外,这给了我一个对象空异常:
Also, this gives me a object null exception:
int blah = (int)cmd.ExecuteScalar();
convert.toint32 和 (int) 不是同一个东西,但一个是另一个的包装器?
isn't convert.toint32 and (int) the same thing but one is a wrapper of the other?
推荐答案
不,你不能.ExecuteScalar() 方法设计为在结果集中返回单个值.基本上第一行第一列的值就返回了.
No, you cannot. The ExecuteScalar() method is designed to return as single value that is returned in a result set. Basically, the value in the first column of the first row returned.
要获得返回值,您需要向您的 SQLCommand 对象添加一个参数.在创建参数对象时使用名称@RETURN_VALUE"并指定返回的参数方向.然后,您可以使用 ExecuteNonQuery() 方法.
To get the return value, you need to add a parameter to your SQLCommand object. Use the name "@RETURN_VALUE" and specify a parameter direction of Return when creating the parameter object. You can then use the ExecuteNonQuery() method.
我必须注意,IMO,存储过程的返回值应该简单地表明过程的状态.所有数据都应通过结果集或输出参数返回.
I must note that IMO, stored procedure return values should simply indicate the status of the procedure. All data should be returned through result sets or output parameters.
这篇关于sproc 使用 RETURN @value 时可以使用 cmd.ExecuteScalar的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:sproc 使用 RETURN @value 时可以使用 cmd.ExecuteScalar
- 在 LINQ to SQL 中使用 contains() 2022-01-01
- 带问号的 nvarchar 列结果 2022-01-01
- 在 C# 中异步处理项目队列 2022-01-01
- 为什么 C# 中的堆栈大小正好是 1 MB? 2022-01-01
- 是否可以在 .Net 3.5 中进行通用控件? 2022-01-01
- CanBeNull和ReSharper-将其用于异步任务? 2022-01-01
- Azure Active Directory 与 MVC,客户端和资源标识同一 2022-01-01
- C# 通过连接字符串检索正确的 DbConnection 对象 2022-01-01
- Windows 喜欢在 LINUX 中使用 MONO 进行服务开发? 2022-01-01
- 使用 rss + c# 2022-01-01