我遇到了一个非常有趣的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:22:10
当你说返回的结果是1--它是如何返回的;结果集还是打印输出?
通常,在使用ExecuteScalar()时,我会使用一个查询来选择单个列值(即格式为SELECT ...出自...)。
https://stackoverflow.com/questions/6861384
复制相似问题