gpt4 book ai didi

sql - ExecuteReader 不返回任何结果,当检查的查询不返回时

转载 作者:行者123 更新时间:2023-12-04 15:04:09 25 4
gpt4 key购买 nike

考虑以下代码:

        StringBuilder textResults = new StringBuilder();
using(SqlConnection connection = new SqlConnection(GetEntityConnectionString()))
{
connection.Open();
m.Connection = connection;
SqlDataReader results = m.ExecuteReader();
while (results.Read())
{
textResults.Append(String.Format("{0}", results[0]));
}
}

我在数据库上的 Sql Server Mgmt Studio 中使用事件监视器来检查正在发送的确切查询。然后,我将该查询文本复制到 SSMS 中的查询编辑器窗口,该查询返回了预期的结果。然而, SqlDataReader results始终为空,表示“枚举没有返回结果”。

我的怀疑是以某种方式没有正确返回结果,这让我认为上面的代码有问题,而不是查询本身被传递。

在上面的代码中有什么会导致这种情况吗?还是我忽略了什么?

编辑:

这是 SQLCommand 对象指示的查询:
SELECT DISTINCT StandardId,Number 
FROM vStandardsAndRequirements
WHERE StandardId IN ('@param1','@param2','@param3')
ORDER BY StandardId

这是出现在事件监视器中的查询:
SELECT DISTINCT StandardId,Number 
FROM vStandardsAndRequirements
WHERE StandardId IN ('ABC-001-0','ABC-001-0.1','ABC-001-0')
ORDER BY StandardId

该查询针对单个 View 工作。

当我对数据库运行第二个查询时,它返回了 3 行。

SqlDataReader 指示 0 行。

最佳答案

你确定是

WHERE StandardId IN ('@param1','@param2','@param3') 

而不是这个?
WHERE StandardId IN (@param1,@param2,@param3) 

参数不应被引用,不在 SQLCommand 对象中。

关于sql - ExecuteReader 不返回任何结果,当检查的查询不返回时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4940350/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com