首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >多次读取IDataReader时出错

多次读取IDataReader时出错
EN

Stack Overflow用户
提问于 2012-08-07 17:09:21
回答 4查看 788关注 0票数 1

我正在尝试将SQL数据库中的数据(1个表中的4列)加载到一个列表中,到目前为止

代码语言:javascript
复制
List<string> FNameList = (from IDataRecord r in myReader
                          select (string)r["FirstName"]).ToList();

List<string> LNameList = (from IDataRecord r in myReader
                          select (string)r["LastName"]).ToList();

List<string> EmailList = (from IDataRecord r in myReader
                          select (string)r["Email"]).ToList();

List<string> PhoneList = (from IDataRecord r in myReader
                          select (string)r["PhoneNumber"]).ToList();

现在我使用的数据库有三行数据,所以每一行的长度都应该是3,但是只有第一行返回的长度是3,其他的返回长度是0。更奇怪的是,如果我注释掉第一个,第二个就可以用了,其他的就不行了。第三个和第四个也是如此。

这很难解释,因为我不能提供用于测试的数据库,所以我想知道上面是否有明显的东西,或者这是否是将列数据加载到数组/列表格式的错误方法。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-08-07 17:21:55

我假设您有一个类似于下面的Select扩展方法:

代码语言:javascript
复制
public static IEnumerable<T> Select<T>(this IDataReader reader, Func<IDataRecord, T> selector)
{
    while(reader.Read())
        yield return selector(reader);
}

因此,当枚举读取器时,它位于可用数据的末尾,再次读取数据的唯一方法是重新发出查询。因此,您需要一次获取所有字段:

代码语言:javascript
复制
var records = (from IDataRecord r in myReader
               select new
               {
                   FirstName = (string)r["FirstName"],
                   LastName = (string)r["LastName"],
                   Email = (string)r["Email"],
                   PhoneNumber = (string)r["PhoneNumber"]
               }).ToList();
票数 3
EN

Stack Overflow用户

发布于 2012-08-07 17:15:02

您的阅读器将在第一次查询后前进到最后一条记录。您需要提取所有行,然后构建您的列表:

代码语言:javascript
复制
var records = (from IDataRecord r in myReader select r).ToArray();

List<string> LNameList = (from IDataRecord r in records
                       select (string)r["LastName"]).ToList();
// Keep the last row for all fields
票数 2
EN

Stack Overflow用户

发布于 2012-08-07 17:16:18

myReader是一个SqlDataReader。The SqlDataReader provides a way of reading a forward-only stream of rows from a SQL Server database。第一次使用后,不能再重新启动。

您需要在单个循环中读取所有数据,然后,如果需要,可以构建列表

然而,我不明白你为什么用这种方式来划分信息。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11842660

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档