为什么调用SqlDataReader.NextResult后没有找到数据?
我的问题是这不起作用;
while (reader.Read())
{
if (reader.NextResult() == true)
{
json.AppendFormat("{{\"AvgDate\": \"{0}\"}},{{\"MarkerID\": \"{1}\"}},", reader["AvgDate"], reader["MarkerID"]);
}
但这是有效的;
while (reader.Read())
{
json.AppendFormat("{{\"AvgDate\": \"{0}\"}},{{\"MarkerID\": \"{1}\"}},", reader["AvgDate"], reader["MarkerID"]);
}
第一个的问题是读者找不到任何数据可以读取。我明白了;
“无数据时尝试读取无效 存在。”
有人能明白为什么吗?
My problem is that this does not work;
while (reader.Read())
{
if (reader.NextResult() == true)
{
json.AppendFormat("{{\"AvgDate\": \"{0}\"}},{{\"MarkerID\": \"{1}\"}},", reader["AvgDate"], reader["MarkerID"]);
}
But this works;
while (reader.Read())
{
json.AppendFormat("{{\"AvgDate\": \"{0}\"}},{{\"MarkerID\": \"{1}\"}},", reader["AvgDate"], reader["MarkerID"]);
}
The problem with the first one is that the reader doesn't find any data to read. I get;
"Invalid attempt to read when no data
is present."
Can anyone see why?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
NextResult() 使读者前进到从查询返回的下一个结果集。按照您编写的方式,它将跳过第一个结果集(可能是唯一的结果集)。
我认为你想要的模式是:
这将检查是否有任何结果,如果有,则读取每个结果集中的结果,直到没有更多的结果可供读取。
编辑:基于评论:
对于 JSON,考虑使用临时对象列表,然后使用 DataContractJsonSerializer:
NextResult() makes the reader advance to the next result set coming back from the query. The way you have it written, it would skip the first result set (likely the only one).
The pattern I think you want is:
This will check if there are any results, and if so, read the results in each result set until there are no more left to read.
EDIT: Based on comment:
For JSON, consider using a list of temporary objects, then a DataContractJsonSerializer:
NextResult 将您带到 Reader 的下一个结果集。您可能只有一个结果集。
NextResult takes you to the next Result Set from the Reader. You probably only have one Result Set.
上面 tvanfosson 的答案中的代码:
应该是:
可能存在没有行的结果集,这会导致前面的代码示例抛出异常。更糟糕的是,第一个结果集可能没有行,并且后面的结果集将无法读取。
但感谢您让我知道 HasRows 的使用原因和方式。
the code from tvanfosson's answer above:
should instead be:
There may be result sets without rows that would cause the previous code example to throw an exception. Worse, the first result set may have no rows, and the later result sets would then not be read.
But thanks for letting me know why and how HasRows is used.