我遇到了一个非常有趣的bug (或特性)。
我有一个调用数据库的ADO Command对象。
调用类似于:
cmd.CommandText = "uspMySearch";
cmd.CommmandType = Command.StoredProcedure.
cmd.Parameters.AddWithValue("@SearchBy", searchBy)
// The value of searchBy is: '( FORMSOF (INFLECTIONAL, steve''s) AND FORMSOF (INFLECTIONAL, game) )'
int result = (int)cmd.ExecuteScalar();
// The result returned is 0. I was expecting 1.当我在SQL/Query Analyzer中执行相同的查询时,我得到了不同的结果。
sql如下所示:
EXEC uspMySearch @SearchBy = '( FORMSOF (INFLECTIONAL, steve''s) AND FORMSOF (INFLECTIONAL, game) )'
// The result returned is 1. This is the expected result.为了确认我调用的是正确的存储过程,我修改了uspMySearch以返回一个随机数。我叫的是正确的Sp!
有谁知道这是怎么回事吗?
谢谢。
史蒂夫
环境
SQL/Server2008 R2
.NET 4.0
发布于 2011-07-28 23:27:14
我相信您在C#中的searchBy变量中有一个无关的单引号,请尝试:
// note steve's rather than steve''s, shouldn't need to escape the single quote
string searchBy =
"( FORMSOF (INFLECTIONAL, steve's) AND FORMSOF (INFLECTIONAL, game) )";
...
cmd.Parameters.AddWithValue("@SearchBy", searchBy);
int result = (int)cmd.ExecuteScalar();@FlyingStreudel在注释中提出的另一种可能性是,您的存储过程没有使用SELECT返回值。如果你使用的是RETURN,你应该尝试:
var retval = new SqlParameter("@RETVAL", SqlDbType.Int);
retval.Direction = ParameterDirection.ReturnValue;
cmd.Parameters.Add(retval);
...
cmd.ExecuteNonQuery();
int result = Convert.ToInt32(retval.Value);发布于 2011-07-28 23:35:53
ExecuteScalar不是用来执行Stored Procedures的-为此,你可以结合使用ExecuteNonQuery和Parameters,方向是Output / InputOutput / Return。
http://msdn.microsoft.com/en-us/library/system.data.parameterdirection.aspx
http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlcommand.aspx
编辑-也许下面的方法也可以(尽管不推荐):
cmd.CommandText = "uspMySearch";
cmd.CommmandType = Command.StoredProcedure;
cmd.Parameters.AddWithValue("@SearchBy", searchBy).Direction = ParameterDirection.InputOutput;
int result = (int)cmd.ExecuteScalar();
var Result = cmd.Parameters ["@SearchBy"].Value;发布于 2011-07-28 23:21:42
我要胡乱猜一猜,但我猜这和你的演员阵容有关。您是否可以将代码更改为:
object result = cmd.ExecuteScalar();并使用调试器检查result变量以查看它是什么(以及它的类型)。这可能会给你(或我)一个关于发生了什么的线索。
https://stackoverflow.com/questions/6861384
复制相似问题