1

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

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。更奇怪的是,如果我注释掉第一个,第二个会起作用,但其他的不起作用。第三个和第四个也是如此。

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

4

4 回答 4

3

我假设你有一个Select类似的扩展方法:

public static IEnumerable<T> Select<T>(this IDataReader reader, Func<IDataRecord, T> selector)
{
    while(reader.Read())
        yield return selector(reader);
}

所以当reader被枚举完后,就到了可用数据的末尾,再次读取数据的唯一方法就是重新发起查询。因此,您需要一次获取所有字段:

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();
于 2012-08-07T09:21:55.193 回答
2

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

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
于 2012-08-07T09:15:02.120 回答
2

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

您需要在一个循环中读取所有数据,然后,如果需要,构建您的列表
但是,我不明白您为什么以这种方式划分信息。

于 2012-08-07T09:16:17.517 回答
1

首先声明一个 poco 来保存属性:

class Person
{
    ...
}

然后是一个辅助方法:

private static IEnumerable<Person> ReadReader(IDataReader reader)
{
    using (reader)
    {
        while (reader.Read())
        {
            yield return new Person
            {
                FirstName = (string)reader["FirstName"],
                LastName = (string)reader["LastName"],
                Email = (string)reader["Email"],
                PhoneNumber = (string)reader["PhoneNumber"]
            }
        }
    }
}

用法:

List<Person> list = RaderReader(command.ExecuteReader()).ToList();
于 2012-08-07T09:16:41.920 回答