我正在尝试将数据(从1个表中的4列)从SQL数据库加载到列表中,并且到目前为止这样做了
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.但是只有第一行返回三个长度;其他人的长度为0.甚至更奇怪的是,如果我注释掉第一个,第二个会起作用,但不会起作用。与第三和第四一样。
由于我无法提供测试数据库,所以很难解释,因此我想知道上面是否有任何明显的内容,或者这是否是将列数据加载到数组/列表格式的错误方法。
答案 0 :(得分:3)
我假设你有一个Select
扩展方法,类似于:
public static IEnumerable<T> Select<T>(this IDataReader reader, Func<IDataRecord, T> selector)
{
while(reader.Read())
yield return selector(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();
答案 1 :(得分: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
答案 2 :(得分:2)
myReader是一个SqlDataReader。 SqlDataReader provides a way of reading a forward-only stream of rows from a SQL Server database
。
第一次使用后无法重新启动。
您需要在一个循环中读取所有数据,然后,如果需要,建立您的列表 但是,我无法理解为什么要以这种方式划分信息。
答案 3 :(得分: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();