【问题标题】:C# - Invalid attempt to call Read when reader is closed [duplicate]C# - 阅读器关闭时调用 Read 的尝试无效[重复]
【发布时间】:2013-06-19 16:01:01
【问题描述】:

我有以下代码:

由于某种原因,它正在生成异常“调用读取阅读器的无效尝试已关闭”。有人可以帮我解决吗?我不知道为什么它会在阅读阅读器的内容后关闭连接时生成此异常。

它正在这一行生成异常:

                    while (rdr.Read())

【问题讨论】:

  • 出于某种原因,这条线results.Load(rdr);造成了麻烦。
  • 它正在将结果加载到数据表中。我声明数据表如下:DataTable results = new DataTable();
  • DataTable 在加载查询结果之前就已经声明好了。在加载查询结果之前,不会以任何其他方式对其进行修改。

标签: c# sql exception


【解决方案1】:

我解决了。

问题是我在读取块中加载数据表。我将代码修改如下,现在可以使用了。

if (rdr.HasRows)
{
    results.Load(rdr);
}

【讨论】:

  • 您可以进一步缩短为:if (rdr.HasRows)
  • 他可以进一步缩短它以完全删除 HasRows 检查。可能不需要。
猜你喜欢
  • 1970-01-01
  • 2013-12-26
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多